結果
| 問題 |
No.58 イカサマなサイコロ
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2022-01-01 15:02:29 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 46 ms / 5,000 ms |
| コード長 | 793 bytes |
| コンパイル時間 | 172 ms |
| コンパイル使用メモリ | 82,252 KB |
| 実行使用メモリ | 60,288 KB |
| 最終ジャッジ日時 | 2024-10-10 04:55:03 |
| 合計ジャッジ時間 | 1,109 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 10 |
ソースコード
n = int(input())
k = int(input())
dice = [i for i in range(1,7)]
dice2 = [i for i in range(4,7)]
dp1 = [0]*(6*n+1)
dp2 = [0]*(6*n+1)
dp1[0] = 1
dp2[0] = 1
for i in range(n):
ndp1 = [0]*(6*n+1)
for j in range(6*n):
for d in dice:
if j+d <= 6*n:
ndp1[j+d] += dp1[j]
dp1 = ndp1
for i in range(n-k):
ndp2 = [0]*(6*n+1)
for j in range(6*n):
for d in dice:
if j+d <= 6*n:
ndp2[j+d] += dp2[j]
dp2 = ndp2
for i in range(k):
ndp2 = [0]*(6*n+1)
for j in range(6*n):
for d in dice2:
if j+d <= 6*n:
ndp2[j+d] += dp2[j]*2
dp2 = ndp2
p = sum(dp1)*sum(dp2)
count = 0
win = 0
for i in range(1,6*n+1):
win += count*dp2[i]
count += dp1[i]
print(win/p)