結果
問題 | No.2646 Cycle Maze |
ユーザー |
👑 |
提出日時 | 2024-03-16 15:00:34 |
言語 | PyPy3 (7.3.15) |
結果 |
TLE
|
実行時間 | - |
コード長 | 888 bytes |
コンパイル時間 | 157 ms |
コンパイル使用メモリ | 82,288 KB |
実行使用メモリ | 248,260 KB |
最終ジャッジ日時 | 2024-09-30 04:01:35 |
合計ジャッジ時間 | 18,270 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 47 TLE * 4 |
ソースコード
h, w, T = map(int, input().split()) si, sj = map(int, input().split()) gi, gj = map(int, input().split()) si -= 1 sj -= 1 gi -= 1 gj -= 1 A = [list(map(int, input())) for _ in range(h)] T -= 1 dp = [False] * (h * w * (T + 1)) def f(t, i, j): return (t * h + i) * w + j dp[f(0, si, sj)] = True di = [0, 1, 0, -1, 0] dj = [1, 0, -1, 0, 0] for t in range(T): for i in range(h): for j in range(w): if not dp[f(t, i, j)]: continue for k in range(5): ni = i + di[k] nj = j + dj[k] if ni < 0 or ni >= h or nj < 0 or nj >= w: continue b = (A[ni][nj] - t - 1) % (A[ni][nj] + 1) if b != 0: dp[f(t + 1, ni, nj)] = True if any(dp[f(t, gi, gj)] for t in range(T + 1)): print("Yes") exit() else: print("No")