atcoder#ARC141B. [ARC141B] Increasing Prefix XOR
[ARC141B] Increasing Prefix XOR
配点 : 点
問題文
正整数 が与えられます。
長さ の正整数列 であって、以下の条件を満たすものの個数を で割った余りを求めてください。
- としたとき、
ただしここで、 はビット単位 演算を表します。
ビット単位 $\mathrm{XOR}$ 演算とは
非負整数 $A, B$ のビット単位 $\mathrm{XOR}$ 、$A \oplus B$ は、以下のように定義されます。
- $A \oplus B$ を二進表記した際の $2^k$ ($k \geq 0$) の位の数は、$A, B$ を二進表記した際の $2^k$ の位の数のうち一方のみが $1$ であれば $1$、そうでなければ $0$ である。
一般に k 個の非負整数 p_1, p_2, p_3, \dots, p_k のビット単位 \mathrm{XOR} は (\dots ((p_1 \oplus p_2) \oplus p_3) \oplus \dots \oplus p_k) と定義され、これは p_1, p_2, p_3, \dots, p_k の順番によらないことが証明できます。
制約
- 入力される値はすべて整数
入力
入力は以下の形式で標準入力から与えられます。
出力
答えを出力してください。
2 4
5
例えば とすると であり、 より が成り立つので条件を満たします。
この他には が条件を満たします。
4 4
0
10 123456789
205695670