【算法】位运算常用语句
1.统计一个整数x中二进制1的个数
while(x){
if(x&1)k++;
x>>=1;
}
while(x){
x-=x&-x;
cnt++;
}
(x>>0&1) //0号位
(x>>1&1) //1号位
(x>>2&1) //2号位
//...
for(int i=0;i<31;i++){
if(x>>i&1){
k++;
}
}
while(x){
x=x&x-1;
k++;
}
2.取出x的k号位的数
printf("%d",x>>k&1);
3.取出后k位
x&(1<<k)-1
4.把k位上的数字取反
即:
0->1
1->0
x^(1<<k)
5.把k号位的数字变成1
x|(1<<k)
6.把k号位的数字变成1
x&(~(1<<k))
~x
表示把x
取反