結果

問題 No.31 悪のミックスジュース
ユーザー letrangerjpletrangerjp
提出日時 2017-06-13 19:51:27
言語 Ruby
(3.3.0)
結果
WA  
実行時間 -
コード長 422 bytes
コンパイル時間 410 ms
コンパイル使用メモリ 7,552 KB
実行使用メモリ 12,672 KB
最終ジャッジ日時 2024-09-24 16:59:14
合計ジャッジ時間 2,435 ms
ジャッジサーバーID
(参考情報)
judge2 / judge5
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 WA -
testcase_01 WA -
testcase_02 WA -
testcase_03 WA -
testcase_04 AC 86 ms
12,160 KB
testcase_05 AC 83 ms
12,160 KB
testcase_06 AC 82 ms
12,160 KB
testcase_07 AC 80 ms
12,160 KB
testcase_08 AC 80 ms
12,288 KB
testcase_09 WA -
testcase_10 AC 80 ms
12,160 KB
testcase_11 WA -
testcase_12 AC 82 ms
12,160 KB
testcase_13 AC 83 ms
12,160 KB
testcase_14 WA -
testcase_15 WA -
testcase_16 WA -
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #

N, V = gets.split.take(2).map(&:to_i)
C = gets.split.take(N).map(&:to_i)

v = V - N
res = C.sum
if v < 1
  p res
  exit
end
I = (0...N).min_by{|i| C[0..i].sum./i+1 }
mul, v = v.divmod(I + 1)
res += C[0..I].sum * mul

$dp = {}
def f(v, i, limit)
  $dp[[v,i]] ||= if v <= 0
    0
  elsif i >= I
    9e99
  else
    (1..limit).map{|lim|
      C[i]*lim + f(v - lim, i + 1, limit - lim)
    }.min
  end
end

p f(v, 0, v) + res
0