結果

問題 No.1858 Gorgeous Knapsack
ユーザー flippergo
提出日時 2026-05-20 09:29:32
言語 PyPy3
(7.3.17)
コンパイル:
pypy3 -mpy_compile _filename_
実行:
pypy3 _filename_
結果
MLE  
実行時間 -
コード長 707 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 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
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

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))
0