【算法】位运算常用语句

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取反

posted @ 2021-12-26 07:57  计算机知识杂谈  阅读(52)  评论(0编辑  收藏  举报