結果
| 問題 | No.1858 Gorgeous Knapsack |
| ユーザー |
siman
|
| 提出日時 | 2022-02-27 20:03:44 |
| 言語 | Ruby (4.0.2) |
| 結果 |
TLE
|
| 実行時間 | - |
| コード長 | 407 bytes |
| 記録 | |
| コンパイル時間 | 188 ms |
| コンパイル使用メモリ | 8,960 KB |
| 実行使用メモリ | 128,768 KB |
| 最終ジャッジ日時 | 2026-03-27 04:56:54 |
| 合計ジャッジ時間 | 17,048 ms |
|
ジャッジサーバーID (参考情報) |
judge2_0 / judge1_0 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 30 TLE * 1 -- * 6 |
コンパイルメッセージ
Syntax OK
ソースコード
N, M = gets.split.map(&:to_i)
J = N.times.map { gets.split.map(&:to_i) }
J.sort_by! { |v, w| -v }
dp = Array.new(N + 1) { Array.new(M + 1, 0) }
ans = 0
J.each_with_index do |(v, w), i|
M.downto(0) do |j|
dp[i + 1][j] = dp[i][j]
nw = j + w
nv = dp[i][j] + v
next if nw > M
if dp[i + 1][nw] < nv
dp[i + 1][nw] = nv
ans = nv * v if ans < nv * v
end
end
end
puts ans
siman