結果

問題 No.527 ナップサック容量問題
ユーザー 0w1
提出日時 2017-08-09 11:03:55
言語 Ruby
(3.4.1)
結果
AC  
実行時間 1,584 ms / 2,000 ms
コード長 387 bytes
コンパイル時間 54 ms
コンパイル使用メモリ 7,552 KB
実行使用メモリ 13,696 KB
最終ジャッジ日時 2024-10-12 03:52:49
合計ジャッジ時間 32,065 ms
ジャッジサーバーID
(参考情報)
judge2 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 37
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #

A = $<.map { |s| s.split.map &:to_i }
N = A.shift[0]
VALUE = A.pop[0]
V, W = A.transpose
dp = [0] + [-1e9.to_i] * 10**5
N.times do |i|
  1e5.to_i.downto(W[i]) do |j|
    dp[j] = [dp[j], V[i] + dp[j - W[i]]].max
  end
end
_ = 0
0.upto(1e5.to_i) do |i|
  _ = [_, dp[i]].max
  dp[i] = [dp[i], _].max
end
puts [1, dp.index(VALUE)].max
puts dp[-1] == VALUE ? :inf : [1, dp.rindex(VALUE)].max
0