atcoder#TOYOTA2023SPRINGFINALC. Count Dividing XOR
Count Dividing 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 の順番によらないことが証明できます。
制約
- 入力される値はすべて整数である
入力
入力は以下の形式で標準入力から与えられる.
出力
答えを出力せよ.
3 6
2
と が条件を満たします.
1 100
124
999000000 1000000000
1726239