NYOJ - 公约数和公倍数

来源:互联网 发布:怎样看是不是淘宝客 编辑:程序博客网 时间:2024/04/30 13:36
描述
小明被一个问题给难住了,现在需要你帮帮忙。问题是:给出两个正整数,求出它们的最大公约数和最小公倍数。
输入
第一行输入一个整数n(0<n<=10000),表示有n组测试数据;
随后的n行输入两个整数i,j(0<i,j<=32767)。
输出
输出每组测试数据的最大公约数和最小公倍数
样例输入
36 612 1133 22
样例输出
6 61 13211 66
#include <iostream>using namespace std;void fun(int m,int n){       int temp,max = m,min = n;if(max < min){        temp = max;max = min;min = temp;}do{temp = max % min;max = min;min = temp;}while(temp);cout<<max<<' '<<(m * n)/max<<endl;}int main(void){int n,num1,num2;cin>>n;while(n--){cin>>num1>>num2;fun(num1,num2);}}
#include <iostream>using namespace std;int main(void){int n,i,j;cin>>n;while(n--){cin>>i>>j;int min = i < j? i : j;for(int step = i; ; step--){if((i % step == 0)&& (j % step == 0)){  cout<<step<<' '<<(i*j)/step<<endl;  break;}}}}

以上,关于公约数和公倍数的两种解法,第一种解法不用多说了,大家基本都知道,第二种,两个数当中,从最小数开始依次递减,遍历整数,找到最大的公约数!
原创粉丝点击