牛客网———求最大连续bit数

文章介绍了两种方法来找到一个int类型数字的二进制表示中最大的连续1的个数。第一种是通过遍历每一位,检查相邻位是否都是1,第二种则是利用位操作,通过n与n<<1相与来消除非连续的1,从而减少时间复杂度。
摘要由CSDN通过智能技术生成

求最大连续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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值