結果
| 問題 |
No.58 イカサマなサイコロ
|
| コンテスト | |
| ユーザー |
siman
|
| 提出日時 | 2016-03-23 00:40:20 |
| 言語 | Ruby (3.4.1) |
| 結果 |
AC
|
| 実行時間 | 99 ms / 5,000 ms |
| コード長 | 1,043 bytes |
| コンパイル時間 | 45 ms |
| コンパイル使用メモリ | 7,424 KB |
| 実行使用メモリ | 12,288 KB |
| 最終ジャッジ日時 | 2024-12-26 06:05:53 |
| 合計ジャッジ時間 | 1,911 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 10 |
コンパイルメッセージ
Syntax OK
ソースコード
class Yukicoder
def initialize
n = gets.to_i
k = gets.to_i
dp_tarou = Array.new(n+1){ Array.new(n*6+2, 0.0)}
dp_jirou = Array.new(n+1){ Array.new(n*6+2, 0.0)}
dp_tarou[0][0] = 1.0
dp_jirou[0][0] = 1.0
1.upto(n) do |i|
0.upto(6*i) do |j|
if dp_tarou[i-1][j] > 0.0
1.upto(6) do |k|
dp_tarou[i][j+k] += 1/6r * dp_tarou[i-1][j]
end
end
end
end
1.upto(n-k) do |i|
0.upto(6*i) do |j|
if dp_jirou[i-1][j] > 0.0
1.upto(6) do |k|
dp_jirou[i][j+k] += 1/6r * dp_jirou[i-1][j]
end
end
end
end
(n-k+1).upto(n) do |i|
0.upto(6*i) do |j|
if dp_jirou[i-1][j] > 0.0
4.upto(6) do |k|
dp_jirou[i][j+k] += 1/3r * dp_jirou[i-1][j]
end
end
end
end
answer = 0.0
0.upto(6*n) do |i|
(i+1).upto(6*n+1) do |j|
answer += dp_tarou[n][i] * dp_jirou[n][j]
end
end
puts answer
end
end
Yukicoder.new
siman