結果
問題 | No.58 イカサマなサイコロ |
ユーザー |
|
提出日時 | 2016-02-28 15:12:43 |
言語 | Go (1.23.4) |
結果 |
AC
|
実行時間 | 2 ms / 5,000 ms |
コード長 | 948 bytes |
コンパイル時間 | 12,272 ms |
コンパイル使用メモリ | 236,664 KB |
実行使用メモリ | 5,248 KB |
最終ジャッジ日時 | 2024-10-10 23:06:54 |
合計ジャッジ時間 | 11,467 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 10 |
ソースコード
package main import ( "bufio" "fmt" "os" "strconv" ) var sc = bufio.NewScanner(os.Stdin) func main() { sc.Split(bufio.ScanWords) n, cheat := nextInt(), nextInt() zdp, tdp := make([]float64, 61), make([]float64, 61) zdp[0], tdp[0] = 1, 1 for i := 0; i < n; i++ { for j := 54; j >= 0; j-- { for k := 1; k < 7; k++ { zdp[j+k] += zdp[j] / 6 } zdp[j] = 0 } } for i := 0; i < n-cheat; i++ { for j := 54; j >= 0; j-- { for k := 1; k < 7; k++ { tdp[j+k] += tdp[j] / 6 } tdp[j] = 0 } } for i := 0; i < cheat; i++ { for j := 54; j >= 0; j-- { for k := 4; k < 7; k++ { tdp[j+k] += tdp[j] / 3 } tdp[j] = 0 } } ans := float64(0) for i := n - cheat + (cheat * 4); i < 61; i++ { for j := i - 1; j >= n; j-- { ans += tdp[i] * zdp[j] } } fmt.Println(ans) } func nextLine() string { sc.Scan() return sc.Text() } func nextInt() int { i, _ := strconv.Atoi(nextLine()) return i }