atcoder#ARC066B. [ABC050D] Xor Sum

[ABC050D] Xor Sum

题目描述

正の整数 N N が与えられます。 2 2 つの整数 u,v(0u,vN) u,v(0≦u,v≦N) であって、ある非負整数 a,b a,b が存在して、a a xor xor b=u b=u a+b=v a+b=v となるようなものが何通りあるかを求めてください。 ここで、xor xor はビットごとの排他的論理和を表します。 なお、答えは非常に大きくなることがあるので、109+7 10^9+7 で割った余りを求めてください。

输入格式

入力は以下の形式で標準入力から与えられる。

N N

输出格式

ありうる 2 2 数の組が何通りあるかを求め、109+7 10^9+7 で割った余りを出力せよ。

题目大意

题目描述

给出正整数NN.

求出整数对uuvv (0u,vN)(0≤u,v≤N)的数目,使得存在两个非负整数aabb满足a xor b=ua\ xor\ b = ua + b=va\ +\ b= v。这里,xorxor表示按位异或。 要求对答案取模109+710^9 + 7

输入输出格式

输入格式

一个正整数NN

输出格式

满足条件的u,vu,v的个数,对109+710^9+7取模

数据范围:

N<=1018N<=10^{18}

3
5
1422
52277
1000000000000000000
787014179

提示

制約

  • 1N1018 1≦N≦10^{18}

Sample Explanation 1

u,v u,v としてありうるものは、以下の 5 5 通りです。 - u=0,v=0 u=0,v=0 a=0,b=0 a=0,b=0 とすると、0 0 xor xor 0=0 0=0 0+0=0 0+0=0 となります。) - u=0,v=2 u=0,v=2 a=1,b=1 a=1,b=1 とすると、1 1 xor xor 1=0 1=0 1+1=2 1+1=2 となります。) - u=1,v=1 u=1,v=1 a=1,b=0 a=1,b=0 とすると、1 1 xor xor 0=1 0=1 1+0=1 1+0=1 となります。) - u=2,v=2 u=2,v=2 a=2,b=0 a=2,b=0 とすると、2 2 xor xor 0=2 0=2 2+0=2 2+0=2 となります。) - u=3,v=3 u=3,v=3 a=3,b=0 a=3,b=0 とすると、3 3 xor xor 0=3 0=3 3+0=3 3+0=3 となります。)