albus就是要第一个出场
题目描述
已知一个长度为 $n$ 的正整数序列 $A$(下标从 $1$ 开始),令 $S = \{ x | 1 \le x \le n \}$,$S$ 的幂集 $2^S$ 定义为 $S$ 所有子集构成的集合。定义映射 $f : 2^S \to Z,f(\emptyset) = 0,f(T) = \mathrm{XOR}\{A_t\}, (t \in T)$。
现在 albus 把 $2^S$ 中每个集合的f值计算出来,从小到大排成一行,记为序列 $B$(下标从 $1$ 开始)。
给定一个数,那么这个数在序列 $B$ 中第 $1$ 次出现时的下标是多少呢?
输入输出格式
输入格式
第一行一个数 $n$, 为序列 $A$ 的长度。接下来一行 $n$ 个数,为序列 $A$,用空格隔开。最后一个数 $Q$,为给定的数.
输出格式
共一行,一个整数,为 $Q$ 在序列 $B$ 中第一次出现时的下标模 $10086$ 的值.
输入输出样例
输入样例 #1
3
1 2 3
1
输出样例 #1
3
说明
【样例解释】
$N = 3,A = [1,2,3]$
$S = \{1,2,3\}$
$2^S = \{\emptyset,\{1\},\{2\},\{3\},\{1,2\},\{1,3\},\{2,3\},\{1,2,3\}\}$
$f(\emptyset) = 0$
$f({1}) = 1$
$f({2}) = 2$
$f({3}) = 3$
$f({1, 2}) = 1 \operatorname{xor} 2 = 3$
$f({1, 3}) = 1 \operatorname{xor} 3 = 2$
$f({2, 3}) = 2 \operatorname{xor} 3 = 1$
$f({1, 2, 3}) = 0$
所以
$B = [0,0,1,1,2,2,3,3]$
【数据范围】
$1 \leq N \leq 10,0000$
其他所有输入均不超过 $10^9$