公约数和公倍数

公约数和公倍数

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

 
输入
第一行输入一个整数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;

}        

 

posted @ 2014-11-02 16:17  -渔人码头-  阅读(341)  评论(0编辑  收藏  举报