結果
問題 | 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 sysinput = sys.stdin.readlinefrom operator import itemgetterN,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]+=yelse: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=0for i in range(30):ANS=max(ANS,max(DP[i]))print(ANS)