题目描述
N 個の相異なる非負整数 A1,A2,…,AN が与えられます。 与えられた数の中から 1 個以上 K 個以下の数を選ぶ方法であって、次の 2 つの条件を満たすような方法は何通りあるか求めてください。
- 選ばれた数のビットごとの論理積は S である。
- 選ばれた数のビットごとの論理和は T である。
输入格式
入力は以下の形式で標準入力から与えられる。
N K S T A1 A2 ... AN
输出格式
答えを出力せよ。
题目大意
hhoppitree 有 n 个非负整数 a1,a2,⋯,an,他想要从中选出至多 k 个整数,使得它们的与为 S,或为 T,求方案数。
3 3 0 3
1 2 3
2
5 3 1 7
3 4 9 1 5
2
5 4 0 15
3 4 9 1 5
3
提示
制約
- 1 ≦ N ≦ 50
- 1 ≦ K ≦ N
- 0 ≦ Ai < 218
- 0 ≦ S < 218
- 0 ≦ T < 218
- Ai = Aj (1 ≦ i < j ≦ N)
Sample Explanation 1
{1,2} もしくは {1,2,3} と数を選ぶと条件を満たします。