博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
基本算法_位运算_lowbit
阅读量:5300 次
发布时间:2019-06-14

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

lowbit运算

lowbit(n)定义为非负整数n在二进制表示下“最低位的1及后面的所有0”构成的数值。比如二进制10011111010的lowbit就是最后两位10。

那么我们如何得到lowbit的值呢?

首先:取反。

 ~ 10011111010

 = 01100000101

然后:+1

   01100000101+1

= 01100000110

我们会发现,此时只有lowbit与原二进制相同,此时再与原数字相与即可得到lowbit(n)

综上可得lowbit的运算公式

  lowbit(n) = n & ( ~ n + 1 ) 

又在补码中,~n+1= - n,所以

  lowbit(n) = n & (- n)

那lowbit有什么应用呢?我们可以求得一个数字二进制中所有1的个数,从而得到0的个数……

只需要不断把n的值赋为n-lowbit( n )即可~

 

转载于:https://www.cnblogs.com/CuteAbacus/p/9464358.html

你可能感兴趣的文章
jenkins搭建
查看>>
C#中使用Split分隔字符串的技巧
查看>>
(springboot)freemarker(二)
查看>>
linux下golang gRPC配置详解
查看>>
mongodb 简单使用说明
查看>>
eclipse的调试方法的简单介绍
查看>>
OneAPM 云监控部署与试用体验
查看>>
加固linux
查看>>
wget 升级
查看>>
为什么需要大数据安全分析?
查看>>
day13.字典复习
查看>>
IPSP问题
查看>>
(转)Java中的String为什么是不可变的? -- String源码分析
查看>>
HNU 10362 A+B for Input-Output Practice (II)
查看>>
iOS——UIButton响应传参数
查看>>
【转帖】关于'eh vector constructor/destructor iterator'的讨论及类的内存分布模型
查看>>
十. 图形界面(GUI)设计9.列表和组合框
查看>>
10.17动手动脑
查看>>
操作系统实验一:并发程序设计
查看>>
互联网协议入门(一)
查看>>