| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 329 人关注过本帖
标题:请教一段代码,为什么?
只看楼主 加入收藏
天天涯涯
Rank: 4
等 级:业余侠客
帖 子:215
专家分:267
注 册:2011-10-17
结帖率:94.74%
收藏
已结贴  问题点数:20 回复次数:2 
请教一段代码,为什么?

int gcd(int a,int b)
{
     if (b == 0)
       return a;
     else
       gcd (b, a % b);
}
这个递归是求最大公约数的,思路是辗转相除,但是这段代码看的有些纠结,请各位帮忙分析一下。
搜索更多相关主题的帖子: return 公约数 
2012-03-09 18:39
zxd675816777
Rank: 7Rank: 7Rank: 7
等 级:黑侠
帖 子:252
专家分:631
注 册:2012-2-3
收藏
得分:10 
这个是递归函数额,好好看看课本,实际上就是在函数内部调用其本身,满足条件的时候再退出。

数学好难!
2012-03-09 19:43
小惚
Rank: 2
等 级:论坛游民
帖 子:14
专家分:29
注 册:2012-2-1
收藏
得分:10 
程序代码:
#include <stdio.h>
#include <stdlib.h>
int gcd(int a,int b)
{
     int c;
     if (b == 0)
     {
       printf("%d  %d\n",a,b);
       return a;
     }
     else
     c=gcd (b, a % b);
     if (c==0)
       return a;
}

int main(void)
{
   int s=gcd(8,6);
   system("paude>nul");
   return 0;
}


[ 本帖最后由 小惚 于 2012-3-9 20:20 编辑 ]
2012-03-09 20:14
快速回复:请教一段代码,为什么?
数据加载中...
 
   



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

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