結果
| 問題 |
No.58 イカサマなサイコロ
|
| コンテスト | |
| ユーザー |
🍡yurahuna
|
| 提出日時 | 2016-02-25 20:02:39 |
| 言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
| 結果 |
AC
|
| 実行時間 | 32 ms / 5,000 ms |
| コード長 | 1,215 bytes |
| コンパイル時間 | 248 ms |
| コンパイル使用メモリ | 12,800 KB |
| 実行使用メモリ | 11,008 KB |
| 最終ジャッジ日時 | 2024-09-22 13:45:56 |
| 合計ジャッジ時間 | 1,223 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 10 |
ソースコード
# -*- coding: utf-8 -*-
N = int(input())
K = int(input())
max_sum = 6 * N
# Taro
# dp1[num_used][cur_sum] = num of such pattern
# 普通のサイコロ→イカサマサイコロの順で考える
dp1 = [[0] * (max_sum + 1) for i in range(N + 1)]
if N - K > 0:
# 普通のサイコロがあるとき
for j in range(1, 6 + 1):
dp1[1][j] = 1
else:
for j in range(4, 6 + 1):
dp1[1][j] = 2
# 配るDP
for n in range(1, N - K):
for s in range(1, max_sum + 1):
for d in range(1, 6 + 1):
if s + d <= max_sum:
dp1[n + 1][s + d] += dp1[n][s]
for n in range(N - K, N):
for s in range(1, max_sum + 1):
for d in range(4, 6 + 1):
if s + d <= max_sum:
dp1[n + 1][s + d] += 2 * dp1[n][s]
# Jiro
dp2 = [[0] * (max_sum + 1) for i in range(N + 1)]
for j in range(1, 6 + 1):
dp2[1][j] = 1
for n in range(1, N):
for s in range(1, max_sum + 1):
for d in range(1, 6 + 1):
if s + d <= max_sum:
dp2[n + 1][s + d] += dp2[n][s]
cumu2 = 0
ans = 0
for s in range(2, max_sum + 1):
cumu2 += dp2[N][s-1]
ans += dp1[N][s] * cumu2
for i in range(2 * N):
ans /= 6
print(ans)
🍡yurahuna