求余运算转换为位运算

因为求余运算要用到除法,除法是比较费时的。因此高性能的程序需要对求余进行转换。
如果被求余数是2的整数次幂,可以用位运算来进行转换,从而得到比较高的效率。

例如求 n % 32 = ???

可以将其转换为  n & (32-1)     

或者  n - (n>>5)<<5

证明比较简单,只要把n表示为二进制即可一目了然。

这个转换用处之一就是位向量的实现。
如下:
enum {BITSPERWORD=32, SHIFT=5, MASK = 0x1F};
void set(int i) { x[i>>SHIFT] |= (1<< (i & MASK)) ;}     //  这里用到了求余的转换,实际是i % 32   
void clr(int i)  { x[i>>SHIFT] &= ~(1<<(i & MASK)); }
bool test(int) { return x[i>>SHIFT] & (1<<(i & MASK)); }

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值