結果
問題 |
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)