社区
C++ 语言
帖子详情
求一个快速的大数求幂的算法
贪食蛇男
2011-09-03 06:24:42
使用数组表示大数,如 123456789123456789123456789 这样的数,
进行逻辑运算。
现在要算 乘方,如 123456 的 123456 次方。
有什么好的办法?
我现在实现的是累乘,慢死了。
1234 ^ 1234 在我的小奔腾双核上都能算一秒多……
有什么快的算法没?求一个。
...全文
422
6
打赏
收藏
求一个快速的大数求幂的算法
使用数组表示大数,如 123456789123456789123456789 这样的数, 进行逻辑运算。 现在要算 乘方,如 123456 的 123456 次方。 有什么好的办法? 我现在实现的是累乘,慢死了。 1234 ^ 1234 在我的小奔腾双核上都能算一秒多…… 有什么快的算法没?求一个。
复制链接
扫一扫
分享
转发到动态
举报
AI
作业
写回复
配置赞助广告
用AI写文章
6 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
guawaziwangzhan
2011-10-10
打赏
举报
回复
同求快速算法!
贪食蛇男
2011-09-04
打赏
举报
回复
没法整。唉。
mengmingtao
2011-09-03
打赏
举报
回复
顶一下。贴个思路代码(编译肯定不过的那种)
string multi(string num1,string num2){
//...
}
string pow(string num,int x){//num 的x次方。这里x用int类型表示
int i=div(x);
int left=x-pow(2,i);
string *power=new string;
*power = powpow(num,i);
*power += pow(num,left);
}
int div(int x){//例子:如x=1025,则x<2^11,但x>2^10,则返回10。
if(x>0){
for(int i = 0;;i++){
if(x<pow(2,i))
return i-1;
}
}
return -1;
}
string powpow(string num,int i){//如果i为2,则2^i = 4,就此函数求num^4
string *pow_i=new string;
*pow_i = num;
for(int temp=0;temp<i;temp++){
*pow_i = multi(pow_i,pow_i);
}
return *pow_i;
}
xunxun
2011-09-03
打赏
举报
回复
[Quote=引用 2 楼 jackyjkchen 的回复:]
楼主请搜索
MKL
[/Quote]
lz请搜索GMPLIB
jackyjkchen
2011-09-03
打赏
举报
回复
楼主请搜索
MKL
ctreewang
2011-09-03
打赏
举报
回复
先帮楼主定了,,接分了,顶,,,,,
大数
模
幂
乘
算法
的
快速
实现
该
算法
用于实现RSA
算法
,新
算法
的效率有明显的提高
C语言
快速
幂
取模
算法
小结
本文实例汇总了C语言实现的
快速
幂
取模
算法
,是比较常见的
算法
。分享给大家供大家参考之用。具体如下: 首先,所谓的
快速
幂
,实际上是
快速
幂
取模的缩写,简单的说,就是
快速
的
求
一个
幂
式的模(余)。在程序设计过程中,经常要去
求
一些
大数
对于某个数的余数,为了得到更快、计算范围更大的
算法
,产生了
快速
幂
取模
算法
。我们先从简单的例子入手:
求
abmodc
算法
1.直接设计这个
算法
: int ans = 1; for(int i = 1;i<=b;i++) { ans = ans * a; } ans = ans % c; 缺点:这个
算法
存在着明显的问题,如果a和b过大,很容易就会溢出。 我们先来看看第
一个
密码学 模n的
大数
幂
乘的
快速
算法
计算x的r方 mod n的
快速
算法
(1)a<-x,b<-r,c<-1 (2)如果b=0,则输出结果c,结束。 (3) 如果b mod 2 !=0,则转到第(5)步。 (4)b<-b/2,a<-(a*a)mod n,转第(3)步。 (5)b<-b-1,c<-(c*a)mod n,转第(2)步。
大数
的
幂
运算和
幂
模运算(加法链和蒙哥马利
算法
的混合)
利用自己定义的
大数
类型,使用加法链和蒙哥马利
算法
的混合
算法
极大的提高了
幂
运算和
幂
模运算的速度。
快速
幂
算法
详解:高效计算
大数
幂
的利器.zip
快速
幂
算法
是一种高效计算
大数
幂
的利器。通过掌握其基本原理和实现方式,并结合实际应用场景进行优化处理,我们可以充分利用其优势,提高
幂
运算的效率。
C++ 语言
65,187
社区成员
250,526
社区内容
发帖
与我相关
我的任务
C++ 语言
C++ 语言相关问题讨论,技术干货分享,前沿动态等
复制链接
扫一扫
分享
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++
技术论坛(原bbs)
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
请不要发布与C++技术无关的贴子
请不要发布与技术无关的招聘、广告的帖子
请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下
试试用AI创作助手写篇文章吧
+ 用AI写文章