求最大公约数、最小公倍数

最大公倍数
若 a、b 全为零则它们的最大公约数不存在;若 a、b 其中之一为零,则它们
的最大公约数为 a、b 中非零的那个;若 a、b 都不为零,则使新 a = b;新 b = a % b 然后重复该过程。
最小公约数
a、b 两数的最小公倍数为两数的乘积除以它们的最大公约数。
题目描述:
输入两个正整数,求其最大公约数。
输入:
测试数据有多组,每组输入两个正整数。
输出:
对于每组输入 ,请输出其最大公约数。
样例输入:
49 14
样例输出:

#include <stdio.h> 
int gcd(int a,int b) { 
if (b == 0) return a; //若b为零则最大公约数为 a 
else return gcd(b,a % b); //否则 ,则改为求 b与a%b 的最大公约数
} 
int main () { 
int a , b; 
while (scanf ("%d%d" ,& a,& b) != EOF ) { //输入两个正整数
printf( "%d\n" ,gcd(a,b)); //输出所求的最大公约数
} 
return 0; 
} 
该代码把求最大公约数的欧几里得算法写成了递归的形式,若读者对理解递归有困难,
这里我们也给出其非递归形式,供读者参考。
代码 3.6 
#include <stdio.h> 
int gcd(int a,int b) { 
while(b != 0) { //只要 b不为 0则一直持续该过程
int t = a % b; 
a = b; //使a变成 b 
b = t; //使b变成 a % b 
} 
return a; //当b为0时,a即是所求
} 
int main () { 
int a , b; 
while (scanf ("%d%d" ,& a,& b) != EOF ) {
printf( "%d\n" ,gcd(a,b)); 
} 
return 0; 
}
全部评论

相关推荐

11-28 17:58
门头沟学院 Java
美团 JAVA开发 n×15.5
牛客786276759号:百度现在晋升很难的 而且云这块的业务没美团好 你看百度股价都跌成啥样了
点赞 评论 收藏
分享
点赞 评论 收藏
分享
沉淀一会:1.同学你面试评价不错,概率很大,请耐心等待; 2.你的排名比较靠前,不要担心,耐心等待; 3.问题不大,正在审批,不要着急签其他公司,等等我们! 4.预计9月中下旬,安心过节; 5.下周会有结果,请耐心等待下; 6.可能国庆节前后,一有结果我马上通知你; 7.预计10月中旬,再坚持一下; 8.正在走流程,就这两天了; 9.同学,结果我也不知道,你如果查到了也告诉我一声; 10.同学你出线不明朗,建议签其他公司保底! 11.同学你找了哪些公司,我也在找工作。
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务