結果
問題 |
No.3076 Goodstuff Deck Builder
|
ユーザー |
![]() |
提出日時 | 2025-03-30 01:53:46 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 2,241 ms / 3,000 ms |
コード長 | 613 bytes |
コンパイル時間 | 350 ms |
コンパイル使用メモリ | 82,284 KB |
実行使用メモリ | 78,528 KB |
最終ジャッジ日時 | 2025-03-30 01:54:19 |
合計ジャッジ時間 | 33,030 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 36 |
ソースコード
import sys input = sys.stdin.readline from operator import itemgetter N,M=map(int,input().split()) POW2=[1] for i in range(50): POW2.append(POW2[-1]*2) CD=[list(map(int,input().split())) for i in range(N)] CD.sort(key=itemgetter(0),reverse=True) DP=[[0]*(M+1) for i in range(30)] for x,y in CD: for i in range(29,-1,-1): for j in range(M+1): if x==0: DP[i][j]+=y else: if j-POW2[i]*x>=0: DP[i+1][j-POW2[i]*x]=max(DP[i+1][j-POW2[i]*x],DP[i][j]+y) ANS=0 for i in range(30): ANS=max(ANS,max(DP[i])) print(ANS)