规律题,打表找规律即可发现

a xor b >= a - b >= gcd(a, b),

如果 a xor b = gcd(a, b) = c 则 c = a - b

枚举倍数c和a判断b即可

但是我主要想讲的是这道题要注意的,就是在跑循环时,一定要注意数组是否越界,比如

int a[maxn];
scanf("%d",&T);
for(int i=1;i<=maxn;++i){
a[i]=i;
}

这样写会造成你读入的T被覆盖,导致输出超限,因为数组a[maxn]不能存数,所以循环不能跑到maxn

这样写就是对的

int a[maxn];
for(int i=1;i<=maxn;++i){
a[i]=i;
}
scanf("%d",&T);

由于你的T是后面读入的,所以不造成影响。

所以各位csper们,要注意预处理千万不要越界!

代码

#include<bits/stdc++.h>
using namespace std;
const int maxn=30000010;
long long ans[maxn+10];//保证不越界
int T,n;
int main(){
for(int c=1;c<=maxn;++c){
for(int a=c*2;a<=maxn;a+=c){
int b=a-c;
if((a^b)==c) ans[a]++;
}
}
for(int i=1;i<=maxn;++i){
ans[i]+=ans[i-1];
}
scanf("%d",&T);
for(int i=1;i<=T;++i){
scanf("%d",&n);
printf("Case %d: %d\n",i,ans[n]);
}
return 0;
}

最新文章

  1. linux内核调试技术之修改内核定时器来定位系统僵死问题
  2. javascript 框架、根基技巧、布局、CSS、控件 JavaScript 类库
  3. Apache ActiveMQの版本更迭和Apache ActiveMQの故障转移
  4. mvc深入理解
  5. PAT 1075. PAT Judge (25)
  6. wifidog auth-server安装配置
  7. RHM-M60型挖掘机力矩限制器/载荷指示器
  8. Jfinal控制器源码解读
  9. R语言学习——图形初阶之折线图与图形参数控制
  10. SpingBoot+Mybaits+Vue,更新学习
  11. MyBatis-Plus 3.0.3 Sql注入器添加,即全局配置Sql注入器,sqlInjector改写
  12. Robot Framework 遇到过的错误 1. Chrome打开无法数据网址,地址栏只显示data:,
  13. 利用apache伪静态技术防止盗链
  14. LVS持久化与超时时间问题分析
  15. hashMap put方法 第三行代码
  16. AppStore应用转让流程
  17. R语言学习——欧拉计划(11)Largest product in a grid
  18. am335x 10.1&quot;电容touch 不能识别
  19. # 20155327 2016-2017-4 《Java程序设计》第9周学习总结
  20. Altium Designer (DXP) 复制粘贴,放器件 出错报异常的原因

热门文章

  1. JDK的命令行工具系列 (二) javap、jinfo、jmap
  2. 调试过程中发现按f5无法走进jdk源码
  3. [ PyQt入门教程 ] PyQt5基本控件使用:消息弹出、用户输入、文件对话框
  4. 关于http 500错误的小结分享
  5. 消息中间件和JMS介绍(一)
  6. android ——网络编程
  7. 【0731 | Day 5】Python基础(三)
  8. Opengl_入门学习分享和记录_番外篇00(MacOS上如何给Xcode 适配openGL)
  9. CodeForces 939F Cutlet
  10. 从0到1发布一个npm包