【算法】位运算常用语句


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<

4.把k位上的数字取反

即:

0->1

1->0

x^(1<

5.把k号位的数字变成1

x|(1<

6.把k号位的数字变成1

x&(~(1<

~x表示把x取反