結果
| 問題 |
No.1538 引きこもりさんは引き算が得意。
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2022-03-24 15:05:09 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 114 ms / 2,000 ms |
| コード長 | 956 bytes |
| コンパイル時間 | 816 ms |
| コンパイル使用メモリ | 82,304 KB |
| 実行使用メモリ | 91,072 KB |
| 最終ジャッジ日時 | 2024-10-12 23:30:04 |
| 合計ジャッジ時間 | 5,161 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 54 |
ソースコード
def yes():
print("Yes")
exit()
def no():
print("No")
exit()
n, k = map(int, input().split())
A = list(map(int, input().split()))
if k in A:
yes()
L = A[:n // 2]
R = A[n // 2:]
def f(A):
pm = set()
p = set()
for a in A:
add = {a}
for s in p:
add.add(s + a)
add2 = set()
for s in p:
add2.add(s - a)
add2.add(a - s)
for s in pm:
for x in [s + a, s - a, -s + a, -s - a]:
add2.add(x)
p |= add
pm |= add2
return p, pm
p1, pm1 = f(L)
p2, pm2 = f(R)
if k in pm1 or k in pm2:
yes()
for s in pm1:
for x in [s + k, s - k, -s + k, -s - k]:
if x in p2 or x in pm2:
yes()
for s in p1:
for x in [s + k, s - k]:
if x in p2 or x in pm2:
yes()
for x in [-s + k, -s - k]:
if x in pm2:
yes()
no()