結果
| 問題 |
No.2364 Knapsack Problem
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2023-06-30 23:34:12 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 57 ms / 3,000 ms |
| コード長 | 613 bytes |
| コンパイル時間 | 205 ms |
| コンパイル使用メモリ | 82,160 KB |
| 実行使用メモリ | 69,484 KB |
| 最終ジャッジ日時 | 2024-07-07 11:26:43 |
| 合計ジャッジ時間 | 2,038 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 20 |
ソースコード
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()))
D = list(map(int, input().split()))
Weight = A + [-c for c in C]
Value = B + [-d for d in D]
nm = N + M
dp = [-(10**9)] * 2**nm
dp[0] = 0
ans = 0
for i in range(2**nm):
if dp[i] == -(10**9):
continue
w = 0
for j in range(nm):
if i >> j & 1:
w += Weight[j]
for j in range(nm):
if i >> j & 1:
continue
if 0 <= w+Weight[j] <= W:
dp[i|1<<j] = max(dp[i|1<<j],dp[i]+Value[j])
print(max(dp))