求一个快速的大数求幂的算法

贪食蛇男 2011-09-03 06:24:42
使用数组表示大数,如 123456789123456789123456789 这样的数,
进行逻辑运算。
现在要算 乘方,如 123456 的 123456 次方。
有什么好的办法?
我现在实现的是累乘,慢死了。
1234 ^ 1234 在我的小奔腾双核上都能算一秒多……
有什么快的算法没?求一个。
...全文
422 6 打赏 收藏 转发到动态 举报
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
  • 打赏
  • 举报
回复
先帮楼主定了,,接分了,顶,,,,,

65,187

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧