本题要求两个给定正整数的最大公约数和最小公倍数。
输入格式:
输入在一行中给出两个正整数M和N(≤1000)。
输出格式:
在一行中顺序输出M和N的最大公约数和最小公倍数,两数字间以1空格分隔。
输入样例:
511 292
输出样例:
73 2044
鸣谢安阳师范学院段晓云老师和软件工程五班李富龙同学补充测试数据!
下面是代码:
#include<iostream>
using namespace std;
int main(){
int a,b;
cin>>a>>b; //输入两个整形数据
for( int i = 2;i <=a && i <= b;i++ ){ //第一个for循环求最大公约数,范围是【2,两数中任意一数】
if( a%i == 0&& b%i ==0 ){
cout<<i;
break;
}
}
printf(" ");
for( int i = a;i <= a*b;i++ ){ //求最小公倍数,范围是【两数中任意一个数 ,两数乘积】
if( i%a==0&&i%b==0 ){
cout<<i;
break;
}
}
return 0;
}