結果
問題 | No.1701 half price |
ユーザー | ntuda |
提出日時 | 2025-01-15 21:42:22 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 227 ms / 3,000 ms |
コード長 | 668 bytes |
コンパイル時間 | 1,460 ms |
コンパイル使用メモリ | 82,312 KB |
実行使用メモリ | 76,200 KB |
最終ジャッジ日時 | 2025-01-15 21:42:28 |
合計ジャッジ時間 | 4,629 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 20 |
ソースコード
from itertools import combinations N,W = map(int,input().split()) A = list(map(int,input().split())) ans = 0 for i in range(1,N + 1): for J in combinations(range(N),i): sumj = 0 for k in J: sumj += A[k] if sumj == W: ans += 1 continue for k in range(1, i + 1): f = False for J2 in combinations(J, k): sumj2 = 0 for k2 in J2: sumj2 += A[k2] if sumj - sumj2//2 == W: ans += 1 f = True break if f: break print(ans)