快速幂取模算法
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了快速幂取模算法,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含520字,纯文字阅读大概需要1分钟。
内容图文
![快速幂取模算法](/upload/InfoBanner/zyjiaocheng/1113/a4e0d9a4febb4553bdf967d346d930e9.jpg)
RSA公钥的加密方法 即 a^b%c;当a,b值较大时,直接求值是很困难的,因而有以下算法:
1:利用公式 (a*b)%c=( (a%c)*b)%c) 对每一步进行处理,由公式可知……该算法仅处理了数据过大的问题,耗时依旧没有解决。
代码如下:
void mmode() { int temp=b; longlong res=1; while(temp--) { res=res*a%c; } cout<<res<<endl; }
2:快速幂取模算法,利用二分法进行优化,即将每次res*a替换为res*a^2优化时间复杂度为O(logN)
代码如下:
void x_mmode() { long long res=1; longlong temp=a; while(b!=0) { if(b%2==1) res=res*temp%c; b/=2; temp=temp*temp%c; } cout<<res<<endl; }
以上为本次幂取模算法的学习
2016.4.19
原文:http://www.cnblogs.com/byzsxloli/p/5407602.html
内容总结
以上是互联网集市为您收集整理的快速幂取模算法全部内容,希望文章能够帮你解决快速幂取模算法所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。