位运算以及快速幂

位运算

1.源码,补码,反码

源码:原来的那个 反码:正数的反码是它本身,负数的反码为 除了符号位之外,其他位取反。 补码:正数的补码不变,负数的补码=反码+1;

2.位运算
逻辑运算:

&& and: 只有两个都为1,结果为1。
^ xor: 1xor1=0 0zor0=0; 1xor0=1; 0xor1=1;
|| or: 0or0=0; 0or1=1; 1or0=0; 1or1=1;

位运算:

1564193039392

快速幂

1.幂取模

要求a的n次方 mod P
方法:折半递归

1.若n为偶数,计算a的n/2次方的平方 2.若a为奇数,求a的n/2次方的平方,在乘a

typedef long long ll;
ll mod;
ll qpow(ll a, ll n)//计算a^n % mod
{
    ll re = 1;
    while(n)
    {
        if(n & 1)//判断n的最后一位是否为1
            re = (re * a) % mod;
        n >>= 1;//舍去n的最后一位
        a = (a * a) % mod;//将a平方
    }
    return re % mod;
}

感谢阅读

代码参考https://www.cnblogs.com/sun-of-Ice/p/9330352.html 感谢!!

转载于:https://www.cnblogs.com/tushukai/p/11254687.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值