結果
問題 | No.2591 安上がりな括弧列 |
ユーザー |
![]() |
提出日時 | 2023-12-19 17:41:54 |
言語 | Ruby (3.4.1) |
結果 |
AC
|
実行時間 | 938 ms / 2,000 ms |
コード長 | 568 bytes |
コンパイル時間 | 463 ms |
コンパイル使用メモリ | 7,552 KB |
実行使用メモリ | 12,800 KB |
最終ジャッジ日時 | 2024-09-27 08:57:06 |
合計ジャッジ時間 | 12,058 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 23 |
コンパイルメッセージ
Syntax OK
ソースコード
def _min(a,b);a < b ? a : b; end N = gets.to_i S = gets.chomp.chars A = gets.split.map(&:to_i) dp = Array.new(N + 1, Float::INFINITY) ndp = Array.new(N + 1, Float::INFINITY) dp[0] = 0 S.zip(A) do |s,a| (0 .. N).each do |d| if s == ?( ndp[d + 1] = _min(dp[d], ndp[d + 1]) if d + 1 <= N ndp[d - 1] = _min(dp[d] + a, ndp[d - 1]) if d - 1 >= 0 else ndp[d + 1] = _min(dp[d] + a, ndp[d + 1]) if d + 1 <= N ndp[d - 1] = _min(dp[d], ndp[d - 1]) if d - 1 >= 0 end end ndp, dp = dp, ndp ndp.fill(Float::INFINITY) end puts dp[0]