結果
| 問題 |
No.2329 Nafmo、イカサマをする
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2023-06-01 11:42:34 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
RE
|
| 実行時間 | - |
| コード長 | 941 bytes |
| コンパイル時間 | 288 ms |
| コンパイル使用メモリ | 81,920 KB |
| 実行使用メモリ | 100,864 KB |
| 最終ジャッジ日時 | 2024-12-28 14:42:50 |
| 合計ジャッジ時間 | 5,057 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 35 RE * 5 |
ソースコード
N,M,K = map(int,input().split())
A = list(map(int,input().split()))
A.append(0)
import sys
k1 = set(A)
k2 = set()
k3 = set()
for a in A:
for b in A:
k2.add(a + b)
for c in A:
k3.add(a + b + c)
if K == 0:
print(0)
exit()
if K == 1:
ans == 0
for a in A:
if ans < a <= M:
ans = a
print(ans)
exit()
D = K // 2
E = K - D
if D == 1:
l = k1
elif D == 2:
l = k2
else:
l = k3
if E == 1:
s = k1
elif E == 2:
s = k2
else:
s = k3
l = sorted(l)
s = sorted(s)
ans = 0
for a in l:
if a + s[-1] <= M:
if a + s[-1] > ans:
ans = a + s[-1]
continue
end = len(s) - 1
if a + s[0] > M:continue
start = 0
while end -start > 1:
mid = end + start >> 1
if a + s[mid] <= M:
start = mid
else:
end = mid
if a + s[start] > ans:
ans = a + s[start]
print(ans)