結果
問題 | No.2591 安上がりな括弧列 |
ユーザー | titia |
提出日時 | 2023-12-19 02:55:37 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 124 ms / 2,000 ms |
コード長 | 507 bytes |
コンパイル時間 | 161 ms |
コンパイル使用メモリ | 82,476 KB |
実行使用メモリ | 76,788 KB |
最終ジャッジ日時 | 2024-09-27 08:36:15 |
合計ジャッジ時間 | 2,890 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 23 |
ソースコード
N=int(input()) S=input() A=list(map(int,input().split())) DP=[1<<60]*(2*N+1) DP[0]=0 for j in range(2*N): s=S[j] NDP=[1<<60]*(2*N+1) if s=="(": for i in range(2*N): NDP[i+1]=min(NDP[i+1],DP[i]) for i in range(1,2*N+1): NDP[i-1]=min(NDP[i-1],DP[i]+A[j]) else: for i in range(2*N): NDP[i+1]=min(NDP[i+1],DP[i]+A[j]) for i in range(1,2*N+1): NDP[i-1]=min(NDP[i-1],DP[i]) DP=NDP print(DP[0])