結果
問題 |
No.2639 Longest Increasing Walk
|
ユーザー |
![]() |
提出日時 | 2024-02-21 12:16:28 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 569 ms / 2,000 ms |
コード長 | 572 bytes |
コンパイル時間 | 238 ms |
コンパイル使用メモリ | 82,720 KB |
実行使用メモリ | 113,332 KB |
最終ジャッジ日時 | 2024-09-29 04:13:37 |
合計ジャッジ時間 | 7,617 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 33 |
ソースコード
H, W = map(int, input().split()) A = [] D = [] for i in range(H): A.append(list(map(int, input().split()))) for j in range(W): D.append((A[i][j], i, j)) D.sort() B = [[1] * W for _ in range(H)] dx = [1, 0, -1, 0] dy = [0, 1, 0, -1] for a, px, py in D: for k in range(4): x = px + dx[k] y = py + dy[k] if x < 0 or x > H - 1 or y < 0 or y > W - 1: continue if A[x][y] >= a: continue B[px][py] = max(B[px][py], B[x][y] + 1) print(max([max(B[i]) for i in range(H)]))