博客
关于我
位运算符 按位与 &——整数n的二进制数中1的个数
阅读量:278 次
发布时间:2019-03-01

本文共 496 字,大约阅读时间需要 1 分钟。

整数n的二进制数中1的个数

编写一个函数,输入是一个整数,返回其二进制表达式中数字位数为 '1' 的个数。

代码如下:

int func(int n) {    int count = 0;    while(n > 0) {        count++;        n &= (n - 1);    }    return count;}

原理:n & (n - 1) 按位与每计算一次,低位减一

当我们用n & (n - 1)进行按位与运算时,每次操作都会将n的最低位1转为0。这个过程不断重复直到n变为0。具体来说,每次循环n都会减少一个二进制位的重量。例如:

  • 对于n = 8(二进制1000),第一次操作后变成0(二进制0000),循环次数为1。
  • 对于n = 3(二进制11),第一次操作后变成2(二进制10),第二次操作后变成0,循环次数为2。

由此可见,n & (n - 1)运算的次数可以用来表示n的二进制中1的位数。

通过上述方法,我们可以快速计算出一个整数的二进制表示中1的个数。这一方法不仅简单高效,而且在时间复杂度上是O(log n),因此非常适用于大范围的整数。

转载地址:http://jwso.baihongyu.com/

你可能感兴趣的文章
Openlayers高级交互(18/20):根据feature,将图形适配到最可视化窗口
查看>>
Openlayers高级交互(19/20): 地图上点击某处,列表中显示对应位置
查看>>
Openlayers高级交互(2/20):清除所有图层的有效方法
查看>>
Openlayers高级交互(20/20):超级数据聚合,页面不再混乱
查看>>
Openlayers高级交互(3/20):动态添加 layer 到 layerGroup,并动态删除
查看>>
Openlayers高级交互(4/20):手绘多边形,导出KML文件,可以自定义name和style
查看>>
Openlayers高级交互(5/20):右键点击,获取该点下多个图层的feature信息
查看>>
Openlayers高级交互(6/20):绘制某点,判断它是否在一个电子围栏内
查看>>
Openlayers高级交互(7/20):点击某点弹出窗口,自动播放视频
查看>>
Openlayers高级交互(8/20):选取feature,平移feature
查看>>
Openlayers高级交互(9/20):编辑图形(放缩、平移、变形、旋转),停止编辑
查看>>
Openlayers:DMS-DD坐标形式互相转换
查看>>
openlayers:圆孔相机根据卫星经度、纬度、高度、半径比例推算绘制地面的拍摄的区域
查看>>
OpenLDAP(2.4.3x)服务器搭建及配置说明
查看>>
OpenLDAP编译安装及配置
查看>>
Openmax IL (二)Android多媒体编解码Component
查看>>
OpenMCU(一):STM32F407 FreeRTOS移植
查看>>
OpenMCU(三):STM32F103 FreeRTOS移植
查看>>
OpenMCU(三):STM32F103 FreeRTOS移植
查看>>
OpenMCU(二):GD32E23xx FreeRTOS移植
查看>>