結果

問題 No.31 悪のミックスジュース
ユーザー letrangerjpletrangerjp
提出日時 2017-06-13 19:51:27
言語 Ruby
(3.3.0)
結果
WA  
実行時間 -
コード長 422 bytes
コンパイル時間 102 ms
コンパイル使用メモリ 11,900 KB
実行使用メモリ 16,772 KB
最終ジャッジ日時 2023-10-24 21:49:18
合計ジャッジ時間 2,545 ms
ジャッジサーバーID
(参考情報)
judge14 / judge13
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 WA -
testcase_01 WA -
testcase_02 WA -
testcase_03 WA -
testcase_04 AC 81 ms
16,080 KB
testcase_05 AC 85 ms
16,076 KB
testcase_06 AC 80 ms
16,080 KB
testcase_07 AC 80 ms
16,084 KB
testcase_08 AC 81 ms
16,080 KB
testcase_09 WA -
testcase_10 AC 82 ms
16,076 KB
testcase_11 WA -
testcase_12 AC 80 ms
16,080 KB
testcase_13 AC 82 ms
16,080 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