結果
問題 |
No.31 悪のミックスジュース
|
ユーザー |
|
提出日時 | 2017-06-13 19:51:27 |
言語 | Ruby (3.4.1) |
結果 |
WA
|
実行時間 | - |
コード長 | 422 bytes |
コンパイル時間 | 410 ms |
コンパイル使用メモリ | 7,552 KB |
実行使用メモリ | 12,672 KB |
最終ジャッジ日時 | 2024-09-24 16:59:14 |
合計ジャッジ時間 | 2,435 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 8 WA * 9 |
コンパイルメッセージ
Syntax OK
ソースコード
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