#ATarc133d. [ARC133D] Range XOR

[ARC133D] Range XOR

题目描述

给定整数 L,R,VL, R, V。请你求满足以下两个条件的整数对 (l,r)(l, r) 的个数,并将结果对 998244353998244353 取模后输出。

  • LlrRL \leq l \leq r \leq R
  • l(l+1)r=Vl \oplus (l+1) \oplus \cdots \oplus r = V

这里,\oplus 表示按位异或(XOR)运算。

按位异或(XOR)运算是这样定义的:对于非负整数 A,BA, BABA \oplus B 的二进制表示中,每一位 2k2^kk0k \geq 0)上的数,如果 AABB 的该位中恰好有一个是 11,则结果的该位为 11,否则为 00

例如,35=63 \oplus 5 = 6(二进制表示为:011101=110011 \oplus 101 = 110)。 一般来说,kk 个非负整数 p1,p2,p3,,pkp_1, p_2, p_3, \dots, p_k 的按位异或为 $(\dots((p\_1 \oplus p\_2) \oplus p\_3) \oplus \dots \oplus p\_k)$,并且可以证明,这个结果与 p1,p2,,pkp_1, p_2, \dots, p_k 的顺序无关。

输入格式

输入从标准输入读取,格式如下:

LL RR VV

输出格式

输出答案。

样例 1

输入

1 3 3

输出

2

样例 2

输入

10 20 0

输出

6

样例 3

输入

1 1 1

输出

1

样例 4

输入

12345 56789 34567

输出

16950

说明/提示

限制

  • 1LR10181 \leq L \leq R \leq 10^{18}
  • 0V10180 \leq V \leq 10^{18}
  • 输入的所有值均为整数

样例解释 1

满足条件的有 (l,r)=(1,2)(l, r) = (1, 2)(l,r)=(3,3)(l, r) = (3, 3),共 22 个。

由 ChatGPT 4.1 翻译