C语言---辗转相除法 HDU 2503

时间:2023-03-09 18:56:29
C语言---辗转相除法 HDU 2503

Problem Description

给你2个分数,求他们的和,并要求和为最简形式。

Input

输入首先包含一个正整数T(T < =1000),表示有T组测试数据,然后是T行数据,每行包含四个正整数a,b,c,d(0 < a,b,c,d<1000),表示两个分数a/b 和 c/d。

Output

对于每组测试数据,输出两个整数e和f,表示a/b + c/d的最简化结果是e/f,每组输出占一行。

Sample Input

2

1 2 1 3

4 3 2 3

Sample Output

5 6

2 1

#include <stdio.h>
int count (int m,int n);
int main (){
int t,a,b,c,d;
int up,down;
scanf("%d",&t);
while(t--){
scanf("%d%d%d%d",&a,&b,&c,&d);
down=b*d;
up=a*d+b*c;
if (down==up){
printf("1 1\n");
continue;
}
printf("%d %d\n",up/count(up,down),down/count(up,down));
}
return 0;
}
int count (int m,int n){
int r,t;
if (m>n){
t=m;
m=n;
n=t;
}
while(m){
r=n%m;
n=m;
m=r;
}
return n; }