結果
| 問題 |
No.2329 Nafmo、イカサマをする
|
| コンテスト | |
| ユーザー |
titia
|
| 提出日時 | 2023-07-25 05:44:32 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 140 ms / 2,000 ms |
| コード長 | 512 bytes |
| コンパイル時間 | 237 ms |
| コンパイル使用メモリ | 82,176 KB |
| 実行使用メモリ | 98,816 KB |
| 最終ジャッジ日時 | 2024-10-02 00:02:08 |
| 合計ジャッジ時間 | 3,398 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 40 |
ソースコード
from bisect import bisect
N,M,K=map(int,input().split())
A=list(map(int,input().split()))+[0]
k=K//2
l=K-k
S={0}
for i in range(k):
NS={0}
for s in S:
for a in A:
if s+a<=M:
NS.add(s+a)
S=NS
X0=sorted(S)
S={0}
for i in range(l):
NS={0}
for s in S:
for a in A:
if s+a<=M:
NS.add(s+a)
S=NS
X1=sorted(S)
ANS=0
for x in X0:
k=bisect(X1,M-x)
if X1[k-1]+x<=M:
ANS=max(ANS,X1[k-1]+x)
print(ANS)
titia