結果
問題 | No.1766 Tatsujin Remix |
ユーザー |
![]() |
提出日時 | 2021-11-26 22:51:56 |
言語 | Crystal (1.14.0) |
結果 |
AC
|
実行時間 | 13 ms / 2,000 ms |
コード長 | 702 bytes |
コンパイル時間 | 13,189 ms |
コンパイル使用メモリ | 297,284 KB |
実行使用メモリ | 7,296 KB |
最終ジャッジ日時 | 2024-06-29 18:21:05 |
合計ジャッジ時間 | 10,565 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 22 |
ソースコード
MOD = 998244353i64 n = read_line.to_i s = Array.new(n) { read_line.chars }.flatten dp = [[0i64, 0i64], [0i64, 0i64]] dp2 = [[1i64, 0i64], [0i64, 0i64]] (n * 16).times do |i| dp, dp2 = dp2, dp dp2.each { |a| a.fill(0i64) } if s[i] != '.' dp2[1][1] = (dp[0][1] + dp[1][1]) % MOD if i % 2 == 0 dp2[0][1] = (dp[0][0] + dp[1][0]) % MOD end else mul = (i != 16 * n - 1 && s[i + 1] != '.') ? 1 : 2 dp2[0][0] = (dp[0][0] + dp[1][0]) % MOD if i % 2 == 1 dp2[1][0] = (dp[0][1] + dp[1][1]) % MOD end dp2[1][1] = (dp[0][1] + dp[1][1]) * mul % MOD if i % 2 == 0 dp2[0][1] = (dp[0][0] + dp[1][0]) * mul % MOD end end end puts dp2.flatten.sum % MOD