結果
問題 | No.2730 Two Types Luggage |
ユーザー |
![]() |
提出日時 | 2024-03-14 14:04:32 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 965 ms / 2,000 ms |
コード長 | 885 bytes |
コンパイル時間 | 317 ms |
コンパイル使用メモリ | 81,920 KB |
実行使用メモリ | 268,892 KB |
最終ジャッジ日時 | 2024-09-29 23:42:16 |
合計ジャッジ時間 | 20,570 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 35 |
ソースコード
# 入力n,m,w = map(int,input().split())A = list(map(int,input().split()))B = list(map(int,input().split()))C = list(map(int,input().split()))# step2で行う処理のために前計算(Aを降順に並び替え累積和を取る。)A.sort(reverse = True)CA = [0]for i in range(n):CA.append(CA[-1] + A[i])# step1. タイプBの荷物の選び方を全探索する。(bit全探索)ans = 0for i in range(1<<m):# 選んだ荷物の総重量cと総価値vc = 0v = 0for j in range(m):# 選ぶif(i >> j & 1):c += B[j]v += C[j]# タイプBのだけで総重量を超えたらパスするif(c > w): continue# step2. ナップザックの残りの容量でタイプAの荷物を詰めれるだけ詰めるv += CA[min(w-c, n)]# 答えの更新ans = max(ans,v)# 出力print(ans)