この問題において、制約の NNN が N≤20N \leq 20N≤20 と小さいので残すべき積み木の組み合わせ 2N≤1048576≒1062^N \leq 1048576 \fallingdotseq 10^62N≤1048576≒106 通りを全て列挙しても余裕で間に合います。(bit全探索)
後はその中から要素の和が KKK になるような組み合わせを一つ見つけて出力すれば良いです。K=0K = 0K=0 のときに一つも積み木を残さない組み合わせを選ばないように注意してください。
時間計算量は組み合わせの列挙に O(2N)O(2^N)O(2N) 、列挙した組み合わせそれぞれに対しその要素の和が KKK に等しいか判定するのに O(N)O(N)O(N) かかるので、全体として O(N×2N)O(N \times 2^N)O(N×2N) となります。