位与运算的应用:

0、对于a%b进行取模和取余操作,如果b=2^k,则用位与运算比取模/余速度更快:a%b=a&(b-1)

1、 用于整数的奇偶性判断,2值状态的切换

     if(a&1)

      { printf(“a是奇数”) } 

else{

  { printf(“a是偶数”) }/*偶数的最低位为0*/

}

2正整数m对2^k取模:m%(2^k)=m&((1<<k)-1)

3掩码:对于数组a[size]掩码是mask =size -1

    对16进制=1<<n -1

 

快速幂取模算法: a^b mod c

// 快速计算 (a ^ p) % m 的值
__int64 FastM(__int64 a, __int64 p, __int64 m)
{
if (p == 0) return 1;
__int64 r = a % m;
__int64 k = 1;
while (p > 1)
{
if ((p & 1)!=0)
{
k = (k * r) % m;
}
r = (r * r) % m;
p >>= 1;
}
return (r * k) % m;
}

转载于:https://www.cnblogs.com/jieruishu/p/10168917.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值