先求出最小公约数,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 人评分
C语言程序设计教程(第三版)课后习题11.1 (C语言代码)浏览:791 |
C语言训练-最大数问题 (C语言代码)浏览:633 |
【出圈】 (C语言代码)浏览:553 |
打水问题 (C语言代码)浏览:1066 |
兰顿蚂蚁 (C++代码)浏览:1044 |
Wu-求圆的面积 (C++代码)浏览:1883 |
C语言程序设计教程(第三版)课后习题4.9 (C语言代码)浏览:560 |
C语言程序设计教程(第三版)课后习题1.6 (C语言代码)浏览:466 |
1013题解浏览:553 |
1025题解浏览:732 |