Java教程

【算法】位运算常用语句

本文主要是介绍【算法】位运算常用语句,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

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

这篇关于【算法】位运算常用语句的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!