結果
問題 | No.2529 Treasure Hunter |
ユーザー |
![]() |
提出日時 | 2024-11-14 21:50:06 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 176 ms / 2,000 ms |
コード長 | 901 bytes |
コンパイル時間 | 451 ms |
コンパイル使用メモリ | 82,368 KB |
実行使用メモリ | 97,288 KB |
最終ジャッジ日時 | 2024-11-14 21:50:11 |
合計ジャッジ時間 | 5,092 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 22 |
ソースコード
T = int(input()) MOD = 998244353 for _ in range(T): W, H = map(int, input().split()) dp = [[0]*3 for _ in range(H)] dp[0][0] = 1 dp[0][1] = W if 4 <= W: dp[0][2] = W*(W-3)//2 for i in range(H-1): dp[i+1][0] = sum(dp[i])%MOD dp[i+1][1] += dp[i][0]*W%MOD dp[i+1][1] %= MOD dp[i+1][1] += dp[i][1]*(W-1)%MOD dp[i+1][1] %= MOD dp[i+1][1] += dp[i][2]*(W-2)%MOD dp[i+1][1] %= MOD if 4 <= W: dp[i+1][2] += dp[i][0]*dp[0][2]%MOD dp[i+1][2] %= MOD if 4 < W: dp[i+1][2] += dp[i][1]*(dp[0][2]-(W-3))%MOD dp[i+1][2] %= MOD dp[i+1][2] += dp[i][2]*(dp[0][2]-((W-3)*2-1))%MOD dp[i+1][2] %= MOD else: dp[i+1][2] += dp[i][1]+dp[i][2] dp[i+1][2] %= MOD print(sum(dp[-1])%MOD)