結果
| 問題 |
No.2095 High Rise
|
| コンテスト | |
| ユーザー |
siman
|
| 提出日時 | 2022-10-10 19:56:35 |
| 言語 | Ruby (3.4.1) |
| 結果 |
AC
|
| 実行時間 | 651 ms / 2,000 ms |
| コード長 | 505 bytes |
| コンパイル時間 | 842 ms |
| コンパイル使用メモリ | 7,552 KB |
| 実行使用メモリ | 30,848 KB |
| 最終ジャッジ日時 | 2024-06-24 16:55:15 |
| 合計ジャッジ時間 | 9,158 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 24 |
コンパイルメッセージ
Syntax OK
ソースコード
N, M = gets.split.map(&:to_i)
A = N.times.map { gets.split.map(&:to_i) }
if N == 1
puts 0
exit
end
dp = Array.new(N) { Array.new(M, Float::INFINITY) }
N.times do |i|
if i == 0
M.times do |j|
dp[i][j] = A[i][j]
end
else
min_v = Float::INFINITY
M.times do |j|
dp[i][j] = dp[i - 1][j] + A[i][j]
min_v = dp[i][j] if min_v > dp[i][j]
end
M.times do |j|
nv = min_v + A[i][j]
dp[i][j] = nv if dp[i][j] > nv
end
end
end
puts dp[N - 1].min
siman