結果
問題 | No.2430 Damage Zone |
ユーザー | 310icecrystal |
提出日時 | 2023-08-18 21:45:42 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 488 ms / 2,000 ms |
コード長 | 849 bytes |
コンパイル時間 | 223 ms |
コンパイル使用メモリ | 82,304 KB |
実行使用メモリ | 116,420 KB |
最終ジャッジ日時 | 2024-11-28 06:26:23 |
合計ジャッジ時間 | 6,530 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 28 |
ソースコード
H,W,K = map(int,input().split()) S = [input() for _ in range(H)] MOD = 998244353 #dp[h][w][k]=マス(h,w)に体力の減少kで行くことができる移動経路の数 dp = [[[0]*K for _ in range(W)] for _ in range(H)] dp[0][0][0] = 1 for h in range(H): for w in range(W): for k in range(K): if h+1 <= H-1: if S[h+1][w] == ".": dp[h+1][w][k] += dp[h][w][k] elif S[h+1][w] == "o" and k <= K-2: dp[h+1][w][k+1] += dp[h][w][k] if w+1 <= W-1: if S[h][w+1] == ".": dp[h][w+1][k] += dp[h][w][k] elif S[h][w+1] == "o" and k <= K-2: dp[h][w+1][k+1] += dp[h][w][k] dp[h][w][k] %= MOD ans = 0 for k in range(K): ans += dp[H-1][W-1][k] ans %= MOD print(ans)