求最大连续bit数
求一个int类型数字对应的二进制数字中1的最大连续数,例如3的二进制为00000011,最大连续2个1。
遍历法
int main()
{
int x;
scanf("%d", &x);
int count=1;
int count_max=0;
for (int i = 0; i < 32; i++) {
if ( (((x >> i) & 1) == 1) && (((x >> (i + 1)) & 1) == 1) )
count++;
else
count = 1;
if (count > count_max)
count_max = count;
}
printf("%d", count_max);
}
我的想法是
1.共32位bit一步一步遍历,每检索到一个1,当前连续数为1,即count=1;
2.当前位和后一位同时为1时,表示当前有两位连续,所以count++;
3.每次比较完,需要记录每次的最大值,即count_max;
4.最后的count_max即为最大连续bit数。
很牛的方法
#include<stdio.h>
int main()
{
int n;
while (scanf("%d", &n) != EOF)
{
int count = 0;
while (n)
{
n = n & (n << 1);
//求一个二进制数有几个1,用n与n-1作&;
//求一个二进制数有几个连续的1,用n与n<<1作&
count++;
}
printf("%d\n", count);
}
return 0;
}
1.求二进制数中有几个1时,n与n-1相与的作用是每次从32位的最右边开始消去一个1,直到最后为0,这样就可以降低时间复杂度。
2.n & (n << 1)每执行一次,若32位中任意一个1的左右都是0时会被消去,只有连续出现的1会被保留,且保留的个数为为执行前最大连续数减一。
//举例n=11时
// 0000 1011 最大连续数为2
// 0001 0110 左移一位
// 0000 0010 两者相与
// 0000 0100 上面结果左移一位
// 0000 0000 结果为0