快速幂取模

在平常的练习中,我们经常需要求a的b次幂模p的结果。这次就专门讲讲这个。

之前,b的规模不是很大。所以我们都是这样做的:

for(int i = 1; i <= b; i++)
    ans *= a, ans %= p;

然而,当b很大时,如10^9时,这种方法就大大滴超时了。。。

为了搞定b较大时的幂取模运算,在这里提一下快速幂取模的方法。

以27^11为例:

1、将11转化为二进制得:1011

2、则原式可转换为:27^(2^3)*27^(2^1)*27(2^0)......(同底数幂的计算)

但感觉这里的27^(2^n)还是很难算。。。还是先看看代码实现吧。

int h = a;
while(b)
{
    if(b & 1)
        ans *= h, ans %= p;
    h*= h, h %= p, b >>= 1;
}

看到这一小段程序的变量h。它就完美地实现了求a^(2^n)的过程(a^n*a^n=a^(2^n) (n≠0))


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值