| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 613 人关注过本帖
标题:递归问题
只看楼主 加入收藏
傲剑
Rank: 2
等 级:论坛游民
帖 子:51
专家分:28
注 册:2009-11-2
结帖率:88.89%
收藏
已结贴  问题点数:20 回复次数:6 
递归问题
递归求最大公约数,没有错误,有警告 不能到达的代码在gcd中,mn小于0时结果正确
#include    <stdio.h>

int gcd(int m,int n);

int main(void)
{
    int m,n,x;
    puts("Please input two numbers:");
    scanf("%d %d",&m,&n);
    x=gcd(m,n);
    printf("The result is %d",x);
    getch();
}

int gcd(int m,int n)
{
    int r;
    if(m<0||n<0)
    return -1;
    r=m%n;
    if(r==0);
    return n;
    if(r>0)
    gcd(n,r);
}
搜索更多相关主题的帖子: 递归 
2010-04-16 22:22
tdy1006
Rank: 4
等 级:业余侠客
帖 子:173
专家分:240
注 册:2009-5-13
收藏
得分:20 
int gcd(int m,int n)
{
    int r;
    if(m<0||n<0)
    return -1;
    r=m%n;
    if(r==0); 多了个分号,如果m<n要交换,改进一理
    return n;
    if(r>0)
    gcd(n,r);
}
2010-04-16 22:29
傲剑
Rank: 2
等 级:论坛游民
帖 子:51
专家分:28
注 册:2009-11-2
收藏
得分:0 
谢谢 这是该过的代码
#include    <stdio.h>

int gcd(int m,int n);

int main(void)
{
    int m,n,x;
    puts("Please input two numbers:");
    scanf("%d %d",&m,&n);
    x=gcd(m,n);
    printf("The result is %d",x);
    getch();
}

int gcd(int m,int n)
{
    int r,temp;
    if(m<0||n<0)
        return -1;
    if(m<n)
        {
        temp=m;
        m=n;
        n=temp;
        }
    r=m%n;
    if(r==0)
        return n;
    if(r>0)
    gcd(n,r);
}
2010-04-16 22:39
南国利剑
Rank: 12Rank: 12Rank: 12
等 级:贵宾
威 望:29
帖 子:1165
专家分:3536
注 册:2010-4-12
收藏
得分:0 
回复 3楼 傲剑
改过后还不行吗?

南国利剑
2010-04-16 22:42
傲剑
Rank: 2
等 级:论坛游民
帖 子:51
专家分:28
注 册:2009-11-2
收藏
得分:0 
改过可以了 ,我都结贴了
2010-04-16 23:07
nunununu
Rank: 2
等 级:论坛游民
帖 子:22
专家分:32
注 册:2010-3-31
收藏
得分:0 
     首先说明的是,c语言函数只能只有一个返回值,如果要多次用到return语句,分支流程一定要设计好
     还有被除数不能为零

#include    <stdio.h>

int gcd(int m,int n);

int main(void)
{
    int m,n,x;
    puts("Please input two numbers:");
    scanf("%d %d",&m,&n);
    x=gcd(m,n);
    printf("The result is %d",x);
    getch();
}

int gcd(int m,int n)
{
    int r,x;
    if(m<0||n<1)
           return -1;
    else /*  添加else语句,使程序要么返回-1,要么返回n,总之只能返回一个值   */
    r=m%n;
           if(r==0)
           return n;
    gcd(n,r);
}



 
2010-04-16 23:24
langren2526
Rank: 2
等 级:论坛游民
帖 子:46
专家分:37
注 册:2010-3-12
收藏
得分:0 
        {
        temp=m;
        m=n;
        n=temp;
        }

这里不是多余的吗?
2010-04-17 11:36
快速回复:递归问题
数据加载中...
 
   



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

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