| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 946 人关注过本帖
标题:求两数的最大公约数
只看楼主 加入收藏
newyj
Rank: 2
等 级:新手上路
威 望:3
帖 子:542
专家分:0
注 册:2008-1-4
收藏
 问题点数:0 回复次数:5 
求两数的最大公约数
例:
int gcd(int v1,int v2){
  while(v2){
    int temp=v2;
    v2=v1%v2;     //这里为什么求模?
    v1=temp;         
  }
  return v1;   
}
能否讲解一下 这个的工作原理 尤其是
int temp=v2;
   v2=v1%v2;
   v1=temp;
搜索更多相关主题的帖子: 最大公约数 
2008-09-11 21:25
blueboy82006
Rank: 5Rank: 5
来 自:幻想世界
等 级:贵宾
威 望:16
帖 子:1227
专家分:57
注 册:2007-7-23
收藏
得分:0 
你知道什么叫"辗转相除法"吗?
建议你看看...
纯属数学问题...

2008-09-11 21:27
newyj
Rank: 2
等 级:新手上路
威 望:3
帖 子:542
专家分:0
注 册:2008-1-4
收藏
得分:0 
哎 还真没听说过呢?
有没有 这方面的书啊(除了数据结构啊!)
2008-09-11 21:44
守鹤
Rank: 4
来 自:山東臨沂
等 级:贵宾
威 望:12
帖 子:337
专家分:0
注 册:2008-6-20
收藏
得分:0 
可以看一下算法设计,上面讲述了许多算法
2008-09-11 22:00
夜风依旧
Rank: 2
等 级:论坛游民
帖 子:42
专家分:20
注 册:2008-5-13
收藏
得分:0 
源于
a = bq + r
带余除法
(a,b) = m

(b,r) = m
依此类推,最终
(x,m) = m

[b]男人,就要对自己很一点。[/b]
2008-09-11 23:34
夜风依旧
Rank: 2
等 级:论坛游民
帖 子:42
专家分:20
注 册:2008-5-13
收藏
得分:0 
最好这样写:
int gcd(int m,int n)
{
    while(n != 0)
    {
        m = m%n;
        if(m == 0)
             return n;
        n = n%m;
    }
    return m;
}
// 这样效率更高了

[b]男人,就要对自己很一点。[/b]
2008-09-11 23:36
快速回复:求两数的最大公约数
数据加载中...
 
   



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

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