trang chủ / bài tập / cowsubsets / lời giải

Tập hợp cân bằng

Chỉ dùng lời giải này khi không có ý tưởng, và đừng copy-paste code từ lời giải này. Hãy tôn trọng người ra đề và người viết lời giải.
Nộp một lời giải chính thức trước khi tự giải là một hành động có thể bị ban.
Tác giả: huunguyenhuunguyen

Lời giải: Tập hợp cân bằng

Hướng tiếp cận

Gặp nhau ở giữa (Meet in the middle): chia N bò thành 2 nửa, liệt kê tất cả tập con của mỗi nửa.

Nhận xét quan trọng

  1. Tập con S cân bằng ↔ tổng T=iSMi chẵn và tồn tại tập con AS với iAMi=T/2.
  2. Chia bò thành nửa trái (H bò) và nửa phải (H2 bò). Với mỗi cặp (lmask,rmask): cần tồn tại sub_llmasksub_rrmask sao cho lsum[sub_l]+rsum[sub_r]=T/2.
  3. Tiền xử lý: với mỗi lmask, tính tập hợp {lsum[sub_l]:sub_llmask} (sắp xếp để tìm kiếm nhị phân).

Thuật toán

  1. Với mỗi lmask (2N/2 giá trị): liệt kê tất cả sub_llmask, lưu lsum vào mảng sắp xếp.
  2. Với mỗi (lmask,rmask): nếu T lẻ → bỏ qua. Với mỗi sub_rrmask, tìm kiếm nhị phân T/2rsum[sub_r] trong mảng của lmask.

Độ phức tạp

  • Thời gian: O(2N/2·3N/2) — chấp nhận được với N20.
  • Bộ nhớ: O(3N/2)

Bình luận

Không có bình luận tại thời điểm này.

gnatmake 12.2.0 a68g 3.1.2 nasm 2.16.1 as_x64 2.46 awk 1.3.4 gcc 16.1.0 csc 6.12.0.200 g++ 16.1.0 g++-themis 16.1.0 g++17 16.1.0 g++20 16.1.0 g++23 16.1.0 clang++ 22.1.6 dmd 2.112.0 dart 3.12.1 gforth 0.7.3 gfortran 12.2.0 go 1.26.3 groovyc 5.0.6 javac 25.0.3 node 26.2.0 kotlinc 2.3.21 sbcl 2.2.9 lua 5.4.8 nim 2.2.10 fpc 3.2.2 fpc-themis 3.2.2 perl 5.36.0 php 8.5.6 pike 8.0 pypy3 7.3.23 python3 3.14.5 racket 8.7 ruby 4.0.5 rustc 1.96.0 csc 5.3.0 ctoj-scratch 0.0.1 sed 4.9 tclsh 8.6 bun 1.3.14 deno 2.8.1 v 0.5.1 zig 0.16.0