結果
| 問題 |
No.66 輝け☆全国たこやき杯
|
| コンテスト | |
| ユーザー |
yaoshimax
|
| 提出日時 | 2015-02-25 22:52:52 |
| 言語 | Python2 (2.7.18) |
| 結果 |
AC
|
| 実行時間 | 265 ms / 5,000 ms |
| コード長 | 785 bytes |
| コンパイル時間 | 164 ms |
| コンパイル使用メモリ | 7,040 KB |
| 実行使用メモリ | 6,944 KB |
| 最終ジャッジ日時 | 2024-06-23 23:28:03 |
| 合計ジャッジ時間 | 1,540 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 10 |
ソースコード
M=int(raw_input())
S=[int(raw_input()) for i in xrange(1<<M)]
prob=[[0.0 for i in xrange(1<<M)] for j in xrange(M+1)]
for i in xrange(1<<M):
prob[0][i]=1.0
for j in xrange(1,M+1):
n_group=1<<j
for a in xrange((1<<M)/n_group):
for left in range(a*n_group,a*n_group+n_group/2):
if a==0 and left > 0:
break
for right in range(a*n_group+n_group/2,(a+1)*n_group):
#print j,":",left,"-",right
prob[j][left] += prob[j-1][left]*prob[j-1][right]*S[left]*S[left]/(S[left]*S[left]+S[right]*S[right])
prob[j][right] += prob[j-1][left]*prob[j-1][right]*S[right]*S[right]/(S[left]*S[left]+S[right]*S[right])
#for a in xrange(1<<M):
# print prob[j][a],
#print
print prob[M][0]
yaoshimax