位运算——判断整数a是否可被2的幂(2、4、8、16……)整除?

// 大部分位运算的技巧早在几十年前就被前辈们在有限的计算环境下“榨”出来了。
// “原创”只是表示这篇文章是我所写,并非翻译或转贴,但也绝不是我“首创”。

能被2^N整除(N >= 1),则a的二进制表示中,低N位全为0,因此:

(a % 2) <==> (a & 1) (a % 4) <==> (a & 3) (a % 8) <==> (a & 7) (a % 16) <==> (a & 15) <==> (a & ((1 << 4) - 1)) ……

现在的编译器已经足够聪明,上面左边的表达式很可能会被自动优化,所以可能看不出求余与按位与的性能差距。
但能在DEBUG模式下快一点,还是有价值的。(设想正常要跑一分钟的程序,调试时需要10分钟才能运行到你所下的断点,会是多么痛苦……)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值