| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 602 人关注过本帖
标题:请教一个关于欧几里得的算法的问题
只看楼主 加入收藏
burningbebe
Rank: 2
等 级:论坛游民
帖 子:41
专家分:19
注 册:2009-10-31
结帖率:100%
收藏
已结贴  问题点数:10 回复次数:4 
请教一个关于欧几里得的算法的问题
小弟是超级新手
做一道题时遇到了求最大公约数 我不知道算法 一查 发现应该用欧几里得定理 但是我在编译时遇到了很多问题 如下
#include <stdio.h>
#include <math.h>
main()
{
    int p,q,a,b;
    printf("Please enter the p and q:\n");
    scanf("%d%d",&p,&q);
    if (p>q)
    {
        b=p%q;
        while(b!=q&&b!=0)
        {
            p=q;
            q=b;
        }
    printf("它们的最大公约数是%d",q);
    }
    else if(p<q)
    {
        a=q%p;
        while(a!=p&&a!=0)
        {
            q=p;
            p=a;
        }
    printf("它们的最大公约数是%d",p);
    }
    else if (p=q)
    {
    printf("它们的最大公约数是%d",p);
   }
}
改程序无法描述 最大公约数的情况 怎么补冲啊   还有一点我很不解
就是我发现 while(a!=p&&a!=0)
中的a!=p&&是不能去掉的 我认为就a!=0就可以了 怎么回事啊
请大家帮帮忙好么?
搜索更多相关主题的帖子: 算法 欧几里得 
2009-11-24 12:20
burningbebe
Rank: 2
等 级:论坛游民
帖 子:41
专家分:19
注 册:2009-10-31
收藏
得分:0 
补充一下 是最大公约数为 1的情况

世界上最遥远的距离不是生与死,而是网通和电信!
2009-11-24 12:21
仰望者
Rank: 2
等 级:论坛游民
帖 子:57
专家分:86
注 册:2009-11-6
收藏
得分:7 
  b=p%q;                           /*当q=1时,b=p*/
        while(b!=0)                 
        {
            p=q;                   /*p=q=1,注意这是赋新值后的p*/
            q=b;                    /*q=b=p,注意这是输入的值p,大于输入的q值,即大于1*/
        }  
    printf("它们的最大公约数是%d",q);/*输出值大于1,而真正是值应该为1,所以错误*/
    }
2009-11-24 12:40
burningbebe
Rank: 2
等 级:论坛游民
帖 子:41
专家分:19
注 册:2009-10-31
收藏
得分:0 
不懂

世界上最遥远的距离不是生与死,而是网通和电信!
2009-11-24 18:14
burningbebe
Rank: 2
等 级:论坛游民
帖 子:41
专家分:19
注 册:2009-10-31
收藏
得分:0 
b=p%q;                           /*当q=1时,b=p*/s 是什么意思?
第一句都不动  如5%1=5?

世界上最遥远的距离不是生与死,而是网通和电信!
2009-11-24 18:16
快速回复:请教一个关于欧几里得的算法的问题
数据加载中...
 
   



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

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