見出し画像

Python で味わう、意外な確率

 前の記事で「Python で関数を定義してグラフを描くまで」やりました。ここでは Python で確率計算することを通じて、ちょっと意外な確率、直感に合わないかも、ちょっと驚くかもしれない確率を味わってみましょう。2つお届けします。

ありふれた偶然

40人のクラスで同じ誕生日の人がいる(誰かと誰かの誕生日が同じである)確率は、どれくらいでしょうか。
 (ア) 10%  (イ) 30%  (ウ) 50%  (エ) 70%  (オ) 90%

 $${n}$$人の誕生日がすべて異なる確率を$${p_n}$$ ,$${n}$$人の中の誰かと誰かの誕生日が一致する確率を$${q_n}$$とします。このとき$${p_n+q_n=1}$$が成り立ちます。ただし、ここではうるう年を考えずに、誕生日を 365 種類として計算します。
 まず$${p_0=1\:,\:p_1=1}$$と$${q_0=0\:,\:q_1=0}$$は明らかです。最低でも 2人いないと、誕生日が一致することはあり得ませんから。また$${n>365}$$のとき$${p_n=0\:,\:q_n=1}$$も明らかです。
 $${p_2}$$は2人目の誕生日が1人目の誕生日と異なる日であると考えて$${p_2=p_1\times364/365}$$で計算できます。同様に $${p_3=p_2\times363/365\;,\;p_4=p_3\times362/365\;,\;…}$$となります。
 一般化すると$${p_{n+1}=p_n\times(365-n)/365}$$(⇔$${p_n=p_{n-1}\times(365-n+1)/365}$$)となります。また$${q_n=1-p_n}$$です。
 さて、これを手計算するのは現実的ではありませんから、計算は Python に任せましょう。では、どうぞ。

席替えしたのにまた同じ席になっちゃう確率

 $${n}$$人のクラスで席替えをします。その際に「席替えしたのにまた同じ席になっちゃったよ」という人が、クラスの中に1人以上いる確率はどれくらいでしょうか?

 何はともあれ、計算してみましょう。「$${n}$$人の人が席替えしたとき、また同じ席になっちゃう人がいる確率」を$${p_n}$$とします。

  • 1人で席替えしたら必ず同じ席になりますから、$${p_1=1}$$です。

  • 2人で席替えする場合、全部で 2 通りのうちの 1 通り → $${p_2=\frac{1}{2}}$$

  • 3人で席替えする場合、全部で 3 ! = 6 通りのうちの 4 通り → $${p_3=\frac{4}{6}}$$

  • (一応書いておくと、$${p_0=0}$$です。)

と、このように順番に数えていってはキリがないので、ここから先は漸化式を立てましょう。
「$${n}$$人の人が席替えしたとき、全員が前と異なる席になる場合の数」を$${a_n}$$とすると、「全員が前と異なる席になる確率」は$${q_n=a_n\div{n!}}$$で、「$${n}$$人の人が席替えしたとき、また同じ席になっちゃう人がいる確率」は$${p_n=1-q_n}$$です。このとき、

  • $${a_n}$$について$${a_{n+2}=(n+1)(a_{n+1}+a_n)}$$… (1) が成り立ち、

  • $${q_n}$$で書き換えると$${(n+2)q_{n+2}=(n+1)q_{n+1}+q_n}$$… (2) となり、

  • $${p_n}$$で書き換えると$${(n+2)p_{n+2}=(n+1)p_{n+1}+p_n}$$… (3) となります。

 高校数列のテクニックでこの漸化式が解けようが解けまいが、私たちには Python という武器がありますから、計算は Python にやらせましょう。では、どうぞ。
※ (1) の計算法や考え方は「完全順列」というワードでネットで検索すれば何かと分かるかもしれません。

《解答編》

 以下、私が作ったコードです。これが必ずしも良いものではないこと、再度申し上げます。

# ありふれた偶然
import matplotlib.pyplot as plt
p=1                     # p:全員の誕生日が異なる確率
for i in range(100):
    p=p*(365-i+1)/365
plt.scatter(i,1-p)      # q:誰かと誰かの誕生日が一致する確率
plt.show()

 「クラスに同じ誕生日の人がいる確率」は$${q_{40}=0.891}$$となりました。というわけで、冒頭の問いの答えは(オ)90% です。意外に高い確率だと思いませんか?
 クラスの中に同じ誕生日の人がいるのは、偶然でも珍しいことでも何でもないんですね。むしろみんなの誕生日が違うことの方がよっぽど珍しいことなんです。

 次に「$${n}$$人の人が席替えしたとき、また同じ席になっちゃう人がいる確率」$${p_n}$$について、初期条件$${p_0=0\:,\:p_1=1}$$と漸化式$${(n+2)p_{n+2}=(n+1)p_{n+1}+p_n}$$… (3) を使って$${p_{10}}$$まで求めました。

import matplotlib.pyplot as plt
p=[0,1,0,0,0,0,0,0,0,0,0]               # p0=0,p1=1は実際の確率。p2以降はダミー
for n in range(9):                      # ┐ 漸化式(3)を使って
    p[n+2]=(p[n+1]*(n+1)+p[n])/(n+2)    # ┘ p2〜p10の値を計算した。
for n in range(11):                     # ┐ p0とp1を含めて、
    print("p",n,"=",p[n])               # │ p0〜p10の値を表示して、
    plt.scatter(n,p[n])                 # ┘ グラフの点をとった。
plt.show()

 結果は上の通りで、実は4人以上のクラスであれば人数に関わらず、その確率は約63%に(正確に言うと,その確率を四捨五入して小数第2位までで表すと0.63に)なります。ところで、その状況は次のケースと同じです。「クリスマス会のプレゼント交換で、みんなが持ち寄ったプレゼントを一人に1個ずつ配ったら、自分が用意したものが自分のところに来ちゃう。クリスマス会に参加したうちの誰かがそういう目にあう」、そうなる確率が約63%だということです。
 この値、意外と大きいと思うんじゃないでしょうか。しかもそれが人数に因らないということも意外なんじゃないでしょうか。

※ ついでながら、$${n}$$を限りなく大きくしていくと、この値は$${1-\dfrac{1}{e}=0.63212055…}$$に近づいていきます。そう、こんなところにネイピア数が現れるんです。それはそれで不思議ですね。

◇      ◇      ◇

Python でグラフを描く 〜 
▷ 関数を定義してグラフを描くまで       
▷ Python で味わう、意外な確率          
▷ 再帰関数  ▷ シェルピンスキーのギャスケット

いいなと思ったら応援しよう!