結果
問題 | No.15 カタログショッピング |
ユーザー |
![]() |
提出日時 | 2025-03-20 21:04:51 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 120 ms / 5,000 ms |
コード長 | 1,463 bytes |
コンパイル時間 | 146 ms |
コンパイル使用メモリ | 82,840 KB |
実行使用メモリ | 87,556 KB |
最終ジャッジ日時 | 2025-03-20 21:05:07 |
合計ジャッジ時間 | 1,605 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 10 |
ソースコード
import sysfrom collections import defaultdictdef main():input = sys.stdin.read().split()idx = 0N = int(input[idx])idx += 1S = int(input[idx])idx += 1P = []for _ in range(N):P.append(int(input[idx]))idx += 1split_at = N // 2a_size = split_atb_size = N - split_at# Precompute all subsets of the first halfa_subsets = defaultdict(list)for mask in range(0, 1 << a_size):total = 0items = []for i in range(a_size):if mask & (1 << i):total += P[i]items.append(i + 1) # 1-based indexa_subsets[total].append(items)solutions = []# Process all subsets of the second halffor mask in range(0, 1 << b_size):total_b = 0items_b = []for j in range(b_size):if mask & (1 << j):total_b += P[split_at + j]items_b.append((split_at + j) + 1) # 1-based indexremaining = S - total_bif remaining in a_subsets:for a_items in a_subsets[remaining]:combined = a_items + items_bif combined: # ensure at least one item is selectedsolutions.append(combined)# Sort the solutions lexicographicallysolutions = sorted(solutions)for sol in solutions:print(' '.join(map(str, sol)))if __name__ == '__main__':main()