結果
| 問題 |
No.2686 商品券の使い道
|
| コンテスト | |
| ユーザー |
titia
|
| 提出日時 | 2024-03-27 01:57:55 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 641 ms / 3,000 ms |
| コード長 | 698 bytes |
| コンパイル時間 | 154 ms |
| コンパイル使用メモリ | 81,664 KB |
| 実行使用メモリ | 92,672 KB |
| 最終ジャッジ日時 | 2024-09-30 14:29:39 |
| 合計ジャッジ時間 | 18,034 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 48 |
ソースコード
import sys
input = sys.stdin.readline
from operator import itemgetter
N,M,Q=map(int,input().split())
AB=[list(map(int,input().split())) for i in range(N)]
DP=[0 for i in range(1<<N)]
DP2=[0 for i in range(1<<N)]
for i in range(1<<N):
c=0
v=0
for j in range(N):
if i & (1<<j) != 0:
c+=AB[j][0]
v+=AB[j][1]
if c<=M:
DP[i]=v
if c<=Q:
DP2[i]=v
#print(DP)
#print(DP2)
for i in range(N):
for j in range(1<<N):
if j & (1<<i) != 0:
DP[j]=max(DP[j],DP[j^(1<<i)])
DP2[j]=max(DP2[j],DP2[j^(1<<i)])
ANS=0
for i in range(1<<N):
ANS=max(ANS,DP[i]+DP2[((1<<N)-1)^i])
print(ANS)
titia