先求出最小公约数,a和b的最小值min一定大于最小公约数,将i从一加到min-1,在枚举中i的最小值即为最小公约数
同时我们知道,最大公约数等于(a*b)/最小公约数=最大公倍数
注意事项:(a*b)/最小公约数=最大公倍数
参考代码:
#include<stdio.h> int main() { int a,b; int min; scanf("%d %d", &a, &b); if ( a<b ) { //求出min min = a; } else { min = b; } int ret = 0; int i; for ( i = 1; i < min; i++ ) { //遍历从1到min-1 if ( a%i == 0 ) { if ( b%i == 0 ) { ret = i; } } } printf("%d\n", ret);//最小公约数 printf("%d\n",(a*b)/ret) ;//最小公倍数 return 0; } #include<stdio.h> int main() { int a,b; int min; scanf("%d %d", &a, &b); min=(a<b)?a:b; int ret = 0; int i; for ( i = 1; i < min; i++ ) { if ( a%i == 0 ) { if ( b%i == 0 ) { ret = i; } } } printf("%d\n", ret);//最小公约数 printf("%d\n",(a*b)/ret) ;//最小公倍数 return 0; }
0.0分
1 人评分
WU-输出正反三角形 (C++代码)浏览:1098 |
WU-判定字符位置 (C++代码)浏览:1471 |
C语言程序设计教程(第三版)课后习题6.8 (C语言代码)浏览:544 |
【求[X,Y]内被除3余1并且被除5余3的整数的和】 (C语言代码)浏览:703 |
C语言程序设计教程(第三版)课后习题5.4 (C语言代码)浏览:585 |
1124题解浏览:630 |
C语言程序设计教程(第三版)课后习题8.7 (C语言代码)浏览:852 |
C语言程序设计教程(第三版)课后习题5.6 (C语言代码)浏览:552 |
字符串对比 (C++代码)浏览:597 |
小九九 (C语言代码)浏览:542 |