結果

問題 No.2639 Longest Increasing Walk
ユーザー vwxyzvwxyz
提出日時 2024-06-01 20:14:12
言語 Python3
(3.13.1 + numpy 2.2.1 + scipy 1.14.1)
結果
AC  
実行時間 1,337 ms / 2,000 ms
コード長 414 bytes
コンパイル時間 376 ms
コンパイル使用メモリ 12,544 KB
実行使用メモリ 52,252 KB
最終ジャッジ日時 2024-12-22 09:05:50
合計ジャッジ時間 16,115 ms
ジャッジサーバーID
(参考情報)
judge1 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 33
権限があれば一括ダウンロードができます

ソースコード

diff #

H,W=map(int,input().split())
A=[list(map(int,input().split())) for h in range(H)]
dp=[[1]*W for h in range(H)]
AHW=[(A[h][w],h,w) for h in range(H) for w in range(W)]
AHW.sort()
for a,h,w in AHW:
    for hh,ww in ((h-1,w),(h+1,w),(h,w-1),(h,w+1)):
        if 0<=hh<H and 0<=ww<W and A[hh][ww]<A[h][w]:
            dp[h][w]=max(dp[h][w],dp[hh][ww]+1)
ans=max(dp[h][w] for h in range(H) for w in range(W))
print(ans)
0