| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 8358 人关注过本帖
标题:如何求两数的最大公约数
取消只看楼主 加入收藏
liyanhong
Rank: 3Rank: 3
来 自:水星
等 级:禁止访问
威 望:8
帖 子:1867
专家分:0
注 册:2008-5-3
收藏
 问题点数:0 回复次数:6 
如何求两数的最大公约数
一:
更相减损
//熟知的辗转相除法变形
main()
{
 int a,b;
 scanf("%d %d",&a,&b);
 while(a!=b)
 {
  if(a>b)
   a-=b;
  else
   b-=a;
 }
 printf("%d",a);
}


二:
辗转相除
//一般用递归描述算法
gcd(m,n)与gcd(n,m mod n)相同 为什么?
gcd(m,0)=m 为什么?
两数不需比较大小也行 为什么 ?

main()
{
 int a,b,r,t;
 scanf("%d %d",&a,&b);
 if(a<b)
 {
  t=a;
  a=b;
  b=t;
 }
 do
 {
  r=a%b;
  a=b;
  b=r;
 }while(r!=0);
    printf("%d",a);
}


三:
连续整数检测
//根据最大公约数的定义来的
main()
{
 int a,b,t;
 scanf("%d %d",&a,&b);
 if(a<b)
  t=a;
 else
  t=b;
 while(t>=1)
 {  if((a%t==0)&&(b%t==0))
       break;
     t--;
 }
 printf("%d",t);
}


四:
短除法
//
两数的公共质因数相乘 p公因数出的次数min{Pa,Pb}
int primedec(int m,int *a)//为什么这函数能求出M的所有质因数?
{
 
 int i=0,k=2;//由最小的质数2除待分解的数
 while(k<=m)
 {
  if(m%k==0)
  {
   a[i++]=k;
   m=m/k;
  }
  else
   k++;
 }

}


main()
{
    int a[10]={0},b[10]={0},c[10];
    int m,n,i,j,k=0,s=1;
    scanf("%d %d",&m,&n);
    primedec(m,a);
    primedec(n,b);
    for(i=0;i<10;i++)
   {
     for(j=0;j<10;j++)
    {
       if(a[i]==b[j]&&b[j]!=0)
      {
        c[k++]=a[i];
        b[j]=0;
       break;
     }
   }
 }
 for(i=0;i<k;i++)
 {
        s*=c[i];   
 }
 printf("%d",s);

}


程序很粗糙……
有不足的地方  还请批评指正
搜索更多相关主题的帖子: 最大公约数 
2008-11-09 20:50
liyanhong
Rank: 3Rank: 3
来 自:水星
等 级:禁止访问
威 望:8
帖 子:1867
专家分:0
注 册:2008-5-3
收藏
得分:0 
//本人拙见  速度是依次递减的
减法是快于除法的   除法的次数影响速度的快慢   
//类似ADT的那种是吧??下次会注意的

爱上你 是 我的错  可是离 开  又舍不得  听着你为我写的歌     好难过
如果说 我说如果  我们还 能  重新来过   不去计 较 谁对谁错  会怎么做
2008-11-09 21:28
liyanhong
Rank: 3Rank: 3
来 自:水星
等 级:禁止访问
威 望:8
帖 子:1867
专家分:0
注 册:2008-5-3
收藏
得分:0 
//
这不是我想知道的


请你把辗转相除的  平均操作次数用数学公式表达出来
并指出它的增长次数

爱上你 是 我的错  可是离 开  又舍不得  听着你为我写的歌     好难过
如果说 我说如果  我们还 能  重新来过   不去计 较 谁对谁错  会怎么做
2008-11-11 17:14
liyanhong
Rank: 3Rank: 3
来 自:水星
等 级:禁止访问
威 望:8
帖 子:1867
专家分:0
注 册:2008-5-3
收藏
得分:0 
是的啊 因为我不会啊……

对于辗转相除    我觉得不能用一般的解决方式来解决
应该用  散点图  或者 计数  来观察
但这样得出来的结果似乎不能让人满意  

就像我猜测它应该是对数阶的一样

爱上你 是 我的错  可是离 开  又舍不得  听着你为我写的歌     好难过
如果说 我说如果  我们还 能  重新来过   不去计 较 谁对谁错  会怎么做
2008-11-11 17:23
liyanhong
Rank: 3Rank: 3
来 自:水星
等 级:禁止访问
威 望:8
帖 子:1867
专家分:0
注 册:2008-5-3
收藏
得分:0 
//那个一个公式不能说明什么东西
递归解决最大公约数问题的确不需要额外的空间和时间
递归的增长次数应该和辗转相除的增长次数是一样的
但是最起码得有一个递推公式吧??
我是不知道怎么写的

爱上你 是 我的错  可是离 开  又舍不得  听着你为我写的歌     好难过
如果说 我说如果  我们还 能  重新来过   不去计 较 谁对谁错  会怎么做
2008-11-11 18:05
liyanhong
Rank: 3Rank: 3
来 自:水星
等 级:禁止访问
威 望:8
帖 子:1867
专家分:0
注 册:2008-5-3
收藏
得分:0 
|k=[lgM](向上取整) (N为底)  
|m(0)=1
|m(k)=m(k-1)+1
|
反向替换 =>m(k)=m(k-i)+i
i换成k-1   =>m(k)=m(1)+k-1=k
k换成 [lgM]
m(n)=[lgM]∈O(lgn)

第一次  推这东西
不知道可对

[[it] 本帖最后由 liyanhong 于 2008-11-11 18:30 编辑 [/it]]

爱上你 是 我的错  可是离 开  又舍不得  听着你为我写的歌     好难过
如果说 我说如果  我们还 能  重新来过   不去计 较 谁对谁错  会怎么做
2008-11-11 18:16
liyanhong
Rank: 3Rank: 3
来 自:水星
等 级:禁止访问
威 望:8
帖 子:1867
专家分:0
注 册:2008-5-3
收藏
得分:0 
看了个数字有什么用  谁信他!!

爱上你 是 我的错  可是离 开  又舍不得  听着你为我写的歌     好难过
如果说 我说如果  我们还 能  重新来过   不去计 较 谁对谁错  会怎么做
2008-11-11 18:37
快速回复:如何求两数的最大公约数
数据加载中...
 
   



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

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