結果
| 問題 |
No.914 Omiyage
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2020-12-13 02:10:56 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 111 ms / 2,000 ms |
| コード長 | 603 bytes |
| コンパイル時間 | 158 ms |
| コンパイル使用メモリ | 82,324 KB |
| 実行使用メモリ | 85,740 KB |
| 最終ジャッジ日時 | 2024-09-19 22:41:40 |
| 合計ジャッジ時間 | 2,012 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 18 |
ソースコード
from bisect import bisect
N,M,K = map(int,input().split())
A = []
for _ in range(N):
a = list(map(int,input().split()))
A.append(a)
N //= 2
B = A[N:]
A = A[:N]
ans = 0
l,r = [],[]
def perm(n,s,arr,h):
global N
if n == len(h):
arr.append(s)
return
for a in h[n]:
if s+a >= K:
continue
perm(n+1,s+a,arr,h)
perm(0,0,l,A)
perm(0,0,r,B)
r.sort()
if l == [] or r == []:
print(-1)
exit()
for i in l:
b = bisect(r,K-i)
if i+r[b-1] > K:
continue
ans = max(ans,i+r[b-1])
if ans == 0:
print(-1)
else:
print(K-ans)