AT_abc129_e [ABC129E] Sum Equals Xor

题目描述

给定一个正整数 $L$,以二进制形式表示。请计算满足以下条件的非负整数对 $(a, b)$ 的个数: - $a + b \leq L$ - $a + b = a\ \text{XOR}\ b$ 由于答案可能非常大,请输出对 $10^9 + 7$ 取模的结果。 XOR 的定义如下: 对于整数 $A, B$,它们的按位异或 $a\ \text{XOR}\ b$ 定义为: 将 $a\ \text{XOR}\ b$ 用二进制表示时,第 $2^k$ 位($k \geq 0$)的值为:如果 $A, B$ 的二进制表示中第 $2^k$ 位只有一个为 $1$,则该位为 $1$,否则为 $0$。例如,$3\ \text{XOR}\ 5 = 6$(二进制为:$011\ \text{XOR}\ 101 = 110$)。

输入格式

输入以以下格式从标准输入读入。 > $L$

输出格式

请输出满足条件的 $(a, b)$ 组数,对 $10^9 + 7$ 取模。

说明/提示

### 限制 - $L$ 以二进制形式给出,首位一定是 $1$ - $1 \leq L < 2^{100001}$ ### 样例解释 1 满足条件的 $(a, b)$ 有 $(0, 0),\ (0, 1),\ (1, 0),\ (0, 2),\ (2, 0)$ 共 $5$ 组。 由 ChatGPT 4.1 翻译