bitcount函数:统计x中值为1的二进制位数

bitcount(unsigned x):

  • 统计x中值为1的二进制位数
  • 将x声明为无符号类型是为了保证将x右移时,无论该程序在什么机器上运行,左边空出的位都是0(而不是符号位)填补。

1、通过右移操作实现

#include <stdio.h>

//通过右移操作实现
int bitcount(unsigned x) {
	int b;
	for(b = 0; x != 0; x >>= 1) {
		if(x & 01) {
			b++;
		}
	}
	
	return b;
}

int main(void) {
	int count = bitcount(17);
	printf("1的总数: %d\n", count);
	return 0;
}

2、通过x &= (x-1)实现

x &= (x-1):可以删除x中最右边值为1的一个二进制位。

//通过 x &= (x-1)实现
int bitcount2(unsigned x) { 
    int countx = 0; 
    while(x) { 
        countx++; 
        x &= (x-1);
		printf("x: %d\n", x);
    }
	
    return countx; 
} 

x & (x-1)用法补充:求x是否是2的n次方

//判断是否是2的次幂
/*
x   = 16	10000
x-1 = 15    01111
	  &	    00000
*/
int isPower2(int x) {
    if((x&(x-1)) == 0)
        return 1;
    else
        return 0;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Star星屹程序设计

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值