\(\\\)

\(Description\)


\(T\) 组询问,每次给出一个 \(a\),求方程

\[a-(a\oplus x)-x=0
\]

的方案数。

  • \(T\le 10^3,a\le 2^{30}\)

\(\\\)

\(Solution\)


我菜又被巨佬 \(Diss\) 了......

考场 \(NC\) 问了爷们半懂不懂的就过了......

移项,得

\[a=(a\oplus x)+x
\]

然后注意到满足这个性质的 \(x\) ,在二进制表示下一定是 \(a\) 的子集。

因为\(a\oplus x\)表示的是两者不交的部分的并集,再加上\(x\)表示的就是两个集合的并再加上 \(x\) 这一集合中 \(a\) 集合不包含的部分。

要是想要这个东西等于 \(a\) ,当且仅当 \(x\) 集合中不在 \(a\) 集合中的部分为空集。

然后就是统计 \(a\) 子集的个数。

显然一开始答案为 \(1\) ,遇到二进制位的一个 \(1\) 就答案个数就会翻倍。

\(\\\)

\(Code\)


#include<cmath>
#include<cstdio>
#include<cctype>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#define R register
#define gc getchar
using namespace std;
typedef long long ll; inline ll rd(){
ll x=0; bool f=0; char c=gc();
while(!isdigit(c)){if(c=='-')f=1;c=gc();}
while(isdigit(c)){x=(x<<1)+(x<<3)+(c^48);c=gc();}
return f?-x:x;
} ll x,ans=1; void work(){
ans=1ll;
x=rd();
while(x){
if((x&1ll)==1ll) ans<<=1;
x>>=1;
}
printf("%I64d\n",ans);
} int main(){
ll t=rd();
while(t--) work();
return 0;
}

最新文章

  1. PSD文件在MAC上和在WINDOWS上的大小有本质区别
  2. iOS: How To Make AutoLayout Work On A ScrollView
  3. django_restframework_angularjs
  4. zabbix电话告警V1
  5. Android动态加载代码技术
  6. OC语法10——@protocol协议,
  7. Advanced Installer 9.8打包实录
  8. vim高亮设置
  9. 设置TrackMouseEvent捕获WM_MOUSEHOVER和WM_MOUSELEAVE消息
  10. python解释执行原理(转载)
  11. Python函数篇(3)-内置函数、文件处理
  12. 基于V4L2摄像头采集图片程序设计
  13. 最简单的基于libVLC的例子:最简单的基于libVLC的视频播放器(图形界面版)
  14. 微信企业向用户银行卡付款API开发详解(PHP)
  15. String 源码探究
  16. python基础之Day7part1集合
  17. Codeforces 985 D - Sand Fortress
  18. linux中文件名有英文括号的问题
  19. runOnUiThread更新主线程
  20. webpack 优化代码 让代码加载速度更快

热门文章

  1. JDBC驱动类型
  2. 笔记本能连上WIFI网络,但是无法上网怎么办
  3. 看opengl写代码(7) 使用混合数组(glInterLeavedArrays)
  4. Justinmind使用教程(2)——计算表达式及条件用法
  5. influxDB+telefraf+grafana
  6. xode5.1.1设置IOS欢迎界面的方法
  7. 千万数据条 用户特征数据 写入mysql
  8. unigui组件中client javascript delphi组件之间的操作
  9. Android源码的下载、编译与导入到Android Studio【转】
  10. loj 6034 线段游戏