結果

問題 No.3076 Goodstuff Deck Builder
ユーザー ゼット
提出日時 2025-03-28 21:29:37
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 2,022 ms / 3,000 ms
コード長 644 bytes
コンパイル時間 202 ms
コンパイル使用メモリ 82,404 KB
実行使用メモリ 77,864 KB
最終ジャッジ日時 2025-03-28 21:30:14
合計ジャッジ時間 35,781 ms
ジャッジサーバーID
(参考情報)
judge5 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 36
権限があれば一括ダウンロードができます

ソースコード

diff #

N,M=map(int,input().split())
dp=[[-10**10]*(M+1) for k in range(12)]
dp[0][0]=0
np=[[-10**10]*(M+1) for k in range(12)]
L=[]
for i in range(N):
  c,d=map(int,input().split())
  L.append((c,d))
L.sort(reverse=True)
p=[1]*12
for k in range(12):
  p[k]=2**k
for i in range(N):
  a,b=L[i][:]
  for x in range(M+1):
    for k in range(12):
      if dp[k][x]<0:
        continue
      if x+a*p[k]>M:
        continue
      np[min(k+1,11)][x+a*p[k]]=max(np[min(k+1,11)][x+a*p[k]],dp[k][x]+b)
  for x in range(M+1):
    for k in range(12):
      dp[k][x]=max(dp[k][x],np[k][x])
result=0
for k in range(12):
  result=max(result,max(dp[k]))
print(result)
0