結果
問題 | No.2317 Expression Menu |
ユーザー |
![]() |
提出日時 | 2023-05-27 08:25:46 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 1,752 ms / 2,000 ms |
コード長 | 885 bytes |
コンパイル時間 | 330 ms |
コンパイル使用メモリ | 82,128 KB |
実行使用メモリ | 297,788 KB |
最終ジャッジ日時 | 2024-12-25 18:04:22 |
合計ジャッジ時間 | 48,186 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 37 |
ソースコード
# 3次元dp、ナップザック # dp[i個目まで][メニューj][容量k]での最高のかわいさ # 事前ソートは必要ないと思う N, X, Y = map(int, input().split()) ABC = [] for i in range(N): a, b, c = map(int, input().split()) ABC.append([a, b, c]) dp = [[[0]*(Y+1) for j in range(X+1)] for i in range(N+1)] dp[0][0][0] = 0 for i in range(1, N+1): a, b, c = ABC[i-1] # not using for j in range(X+1): for k in range(Y+1): dp[i][j][k] = max(dp[i][j][k], dp[i-1][j][k]) #dp[i][j][k] = dp[i-1][j][k] # using for j in range(X+1): for k in range(Y+1): if j+a <= X and k+b <= Y: dp[i][j+a][k+b] = max(dp[i][j+a][k+b], dp[i-1][j][k]+c) #print(dp[i]) ans = 0 for j in range(X+1): for k in range(Y+1): ans = max(ans, dp[N][j][k]) print(ans)