|
网站首页
|
业界新闻
|
小组
|
威客
|
人才
|
下载频道
|
博客
|
代码贴
|
在线编程
|
编程论坛
|
登录
注册
短消息
我发表的主题
我参与的主题
我收藏的贴子
我上传的附件
我下过的附件
编辑个人资料
我的博客
用户控制面板
搜索
道具
恢复默认风格
碧海青天
秋意盎然
棕红预览
粉色回忆
蓝雅绿
紫色淡雅
青青河草
e点小镇
橘子红了
红红夜思
水晶紫色
雪花飘飘
新年快乐
风格
短消息
论坛展区
帮助
编程论坛
→
开发语言
→
『 C语言论坛 』
→ 关于大数取模
我的收件箱(0)
欢迎加入我们,一同切磋技术
用户名:
密 码:
共有
2491
人关注过本帖
标题:
关于大数取模
只看楼主
加入收藏
以飒
等 级:
新手上路
帖 子:1
专家分:0
注 册:2007-9-22
楼主
收藏
问题点数:0 回复次数:1
关于大数取模
输入一个数a,求他的n(n是一个相当大的数字)次方,然后对另一个数m取模,这个算法如何优化,我觉得可以用
for(i=1,j=1;i<=n;i++)
{ j=j*a%m;
}
缩短程序时间,但是好像还是不够省时,我觉得关键在于成的n次方,有什么办法可以优化这一步骤吗?请各位大虾解答,谢谢。我很想知道。
搜索更多相关主题的帖子:
大数
2008-03-14 18:36
举报帖子
使用道具
赠送鲜花
iFreeBSD
等 级:
业余侠客
威 望:
4
帖 子:474
专家分:236
注 册:2007-11-5
第
2
楼
收藏
得分:0
procedure(int a , int n[k-1....0] , int m) /* n[k-1....0] 数组n[]存储指数n的二进制数 */
int x := 1
power := a mod m
for i := 0 to k - 1 ;
begin
if a[i] == 1 then x := (x * power) mod m
power := (power * power) mod m
end
return x
复杂度O(logN)
without further ado, let’s get started
2008-03-14 20:38
举报帖子
使用道具
赠送鲜花
2
1/1页
1
快速回复:
关于大数取模
数据加载中...
关于我们
|
广告合作
|
编程中国
|
清除Cookies
|
TOP
|
手机版
编程中国
版权所有,并保留所有权利。
Powered by
Discuz
, Processed in 0.017546 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved