博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
快速幂取模
阅读量:5939 次
发布时间:2019-06-19

本文共 733 字,大约阅读时间需要 2 分钟。

int quick(int a,int b,int c)  

{  
    int ans=1;   //记录结果  
    a=a%c;   //预处理,使得a处于c的数据范围之下  
    while(b!=0)  
    {  
        if(b&1) ans=(ans*a)%c;   //如果b的二进制位不是0,那么我们的结果是要参与运算的  
        b>>=1;    //二进制的移位操作,相当于每次除以2,用二进制看,就是我们不断的遍历b的二进制位  
        a=(a*a)%c;   //不断的加倍  
    }  
    return ans;  
}

对于任何一个整数的模幂运算  

a^b%c  
对于b我们可以拆成二进制的形式  
b=b0+b1*2+b2*2^2+...+bn*2^n  
这里我们的b0对应的是b二进制的第一位  
那么我们的a^b运算就可以拆解成  
a^b0*a^b1*2*...*a^(bn*2^n)  
对于b来说,二进制位不是0就是1,那么对于bx为0的项我们的计算结果是1就不用考虑了,我们真正想要的其实是b的非0二进制位  
  
那么假设除去了b的0的二进制位之后我们得到的式子是  
a^(bx*2^x)*...*a(bn*2^n)  
这里我们再应用我们一开始提到的公式,那么我们的a^b%c运算就可以转化为  
(a^(bx*2^x)%c)*...*(a^(bn*2^n)%c)  
这样的话,我们就很接近快速幂的本质了

(a^(bx*2^x)%c)*...*(a^(bn*2^n)%c)  

我们会发现令  
A1=(a^(bx*2^x)%c)  
...  
An=(a^(bn*2^n)%c)  
这样的话,An始终是A(n-1)的平方倍(当然加进去了取模匀速那),依次递推

转载于:https://www.cnblogs.com/wander-clouds/p/8443690.html

你可能感兴趣的文章
我的友情链接
查看>>
第一本docker书学习笔记1-3章
查看>>
一個典型僵尸網絡淺析
查看>>
vmware克隆Centos6.4虚拟机网卡无法启动问题
查看>>
dba学习
查看>>
asterisk配置
查看>>
GA操作步骤和技巧(二)——用户行为分析
查看>>
shell中while循环里使用ssh的注意事项
查看>>
SHELL获取计算机外网ip的几种写法
查看>>
博客正在搬迁中
查看>>
触发器与存储过程的区别
查看>>
我的友情链接
查看>>
centos搭建supervisor
查看>>
linux日志分割
查看>>
Samba再报安全漏洞
查看>>
我的友情链接
查看>>
我的友情链接
查看>>
Spring学习资料之 依赖注入(一)
查看>>
安装win7提示安装程序无法创建新的系统分区和定位现有系统分区
查看>>
那些年,我跳过的坑(一)
查看>>