天天看点

公约数和公倍数

公约数和公倍数

描述小明被一个问题给难住了,现在需要你帮帮忙。问题是:给出两个正整数,求出它们的最大公约数和最小公倍数。

输入第一行输入一个整数n(0<n<=10000),表示有n组测试数据; 随后的n行输入两个整数i,j(0<i,j<=32767)。输出输出每组测试数据的最大公约数和最小公倍数样例输入

3
6 6
12 11
33 22           

复制

样例输出

6 6
1 132
11 66           

复制

#include<iostream>
using namespace std;
int gcd(int a,int b)
{

    int min=(a<b)?a:b;
    int max=(a>b)?a:b;
    while(min!=0)
    {
    int k = max%min;
    max=min;
    min=k;
    }
    return max;

}
int main()
{
    int test ;
    int num1,num2;
    cin>>test;
    while(test--)
    {
        cin>>num1>>num2;
        int kk = (num1 * num2)/gcd(num1,num2);

        cout<<gcd(num1,num2)<<" "<<kk<<endl;

    }
    return 0;

}                   

复制