求解释下,看不太懂(用递归求最大公约数)

zylmtz2012 2012-11-25 09:40:57
#include <iostream>
using namespace std;
int gcd(int x, int y);
void main()
{
int m,n;
cout<<"输入两个数字:";
cin>>m>>n;
cout<<"最大公约数:";
cout<<gcd(m,n)<<endl;
}
int gcd(int a, int b)
{
int g;
if (b==0)
g=a;
else
g=gcd(b,a%b);
return g;
}
...全文
99 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
转角天边 2012-11-25
  • 打赏
  • 举报
回复
一个递归
阿七哥 2012-11-25
  • 打赏
  • 举报
回复
楼主你好,让我来为你解答。 程序首先分为两部分:主函数和gcd函数(); 例如:当你在主函数中输入m=2,n=4;时,将值传递到gcd函数中,则此时,a=2;b=4; 因为不满足if语句部分,则执行else语句部分。 g=gcd(4,2%4); 则此时a=4;b=0; 因为满足if语句部分,则g=4; 则返回g。 由此分析这个程序有点缺陷吧。你输入2,4和输入4,2会得到不同的结果。
newtee 2012-11-25
  • 打赏
  • 举报
回复
不会就画递归图
_程序员 2012-11-25
  • 打赏
  • 举报
回复
递归就是自己调用 自己,有什么不好理解的?还是你不理解约数的原理?

64,682

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧