結果
| 問題 | No.1858 Gorgeous Knapsack |
| ユーザー |
|
| 提出日時 | 2026-05-20 09:29:32 |
| 言語 | PyPy3 (7.3.17) |
| 結果 |
MLE
|
| 実行時間 | - |
| コード長 | 707 bytes |
| 記録 | |
| コンパイル時間 | 225 ms |
| コンパイル使用メモリ | 85,248 KB |
| 実行使用メモリ | 669,952 KB |
| 最終ジャッジ日時 | 2026-05-20 09:29:50 |
| 合計ジャッジ時間 | 15,288 ms |
|
ジャッジサーバーID (参考情報) |
judge1_0 / judge2_1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 33 MLE * 4 |
ソースコード
N,M = map(int, input().split())
A = [list(map(int, input().split())) for _ in range(N)]
A = [0]+sorted(A,key=lambda x:x[0],reverse=True)
INFTY = 10**16
F = [[0 for _ in range(M+1)] for _ in range(N+1)]
G = [[0 for _ in range(M+1)] for _ in range(N+1)]
H = [[0 for _ in range(M+1)] for _ in range(N+1)]
for j in range(1,M+1):
if j>=A[1][1]:
F[1][j] = A[1][0]**2
else:
F[1][j] = -INFTY
for i in range(2,N+1):
for j in range(1,M+1):
G[i][j] = max(F[i-1][j],G[i-1][j])
H[i][j] = max(F[i-1][j]//A[i-1][0],H[i-1][j])
if j>=A[i][1]:
F[i][j] = H[i][j-A[i][1]]*A[i][0]+A[i][0]**2
else:
F[i][j] = -INFTY
print(max(F[N][M],G[N][M],0))