TouchStone
  请登录后使用
登录 注册
 系统首页  练习题库  考试列表  判题结果  信息发布  解题排行
  • 首页
  • 题库
  • P1620
  • 题目
  • P1620GCD和XOR
    限制 : 时间限制 : - MS   空间限制 : 524288 KB
    评测说明 : 3s,512MB
    问题描述

    老八想要统计这样的 \((a,b)\) 有多少对:

    • $1\leq a\leq b\leq n$
    • \(\gcd(a,b)=a\texttt{ xor }b\)

    老八初学编程,只会计算 \(n\leq 10^3\) 时的答案。

    请你帮忙写个程序计算 \(n\leq 3\times 10^{7}\) 的答案。

    输入格式

    第一行一个整数 \(T\) ,接下来 \(T\) 行每行一个整数 \(n\)

    输出格式

    每行一个整数答案。

    提示

    样例1

    样例输入

    2
    7
    20000000
    

    样例输出

    4
    34866117
    

    样例解释
    \(n=7\) 时符合要求的 \((a,b)\)\((2,3),(4,5),(4,6),(6,7)\)

    数据范围

    对于20%的数据, $1\leq T\leq 10$ , $1\leq n\leq 10^3$ ;

    对于60%的数据, $1\leq T\leq 10^4$ , $1\leq n\leq 10^6$ ;

    对于100%的数据, $1\leq T\leq 10^4$ , $1\leq n\leq 3\times 10^7$ 。