| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2491 人关注过本帖
标题:关于大数取模
只看楼主 加入收藏
以飒
Rank: 1
等 级:新手上路
帖 子: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
Rank: 4
等 级:业余侠客
威 望:4
帖 子:474
专家分:236
注 册:2007-11-5
收藏
得分: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
快速回复:关于大数取模
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.039756 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved