結果

問題 No.127 門松もどき
ユーザー yaoshimax
提出日時 2015-04-26 09:06:58
言語 PyPy2
(7.3.15)
結果
AC  
実行時間 712 ms / 5,000 ms
コード長 536 bytes
コンパイル時間 1,012 ms
コンパイル使用メモリ 76,928 KB
実行使用メモリ 215,040 KB
最終ジャッジ日時 2024-12-23 22:28:46
合計ジャッジ時間 10,932 ms
ジャッジサーバーID
(参考情報)
judge3 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other AC * 23
権限があれば一括ダウンロードができます

ソースコード

diff #

N=int(raw_input())
A=map(int,raw_input().split())
dpL=[[1 for j in range(N+1)] for k in range(N+1)]
dpR=[[1 for j in range(N+1)] for k in range(N+1)]
ans=1
for d in range(1,N):
    for l in range(N-d):
        # update l,l+d
        dpR[l][l+d]=dpR[l+1][l+d]
        dpL[l][l+d]=dpL[l][l+d-1]
        if A[l]<A[l+d]:
            dpL[l][l+d]=max(dpL[l][l+d],dpR[l+1][l+d]+1)
        elif A[l]>A[l+d]:
            dpR[l][l+d]=max(dpR[l][l+d],dpL[l][l+d-1]+1)
        ans=max(ans,dpL[l][l+d])
        ans=max(ans,dpR[l][l+d])

print ans


0