Description
编写一个C程序,实现两个分数的加减法
Input
输入包含多行数据
每行数据是一个字符串,格式是”a/boc/d”。
其中a, b, c, d是一个0-9的整数。o是运算符”+”或者”-“。
数据以EOF结束
输入数据保证合法
Output
对于输入数据的每一行输出两个分数的运算结果。
注意结果应符合书写习惯,没有多余的符号、分子、分母,并且化简至最简分数
Sample Input
1/8+3/8
1/4-1/2
1/3-1/3
Sample Output
1/2
-1/4
0
Solution
辗转相除法
Code
#include<stdio.h>
int gcd(int x,int y)
{
while(y!=0)
return gcd(y,x%y);
return x;
}
int main()
{
int a,b,c,d;
char s;
while(scanf("%d/%d%c%d/%d",&a,&b,&s,&c,&d)!=EOF)
{
int son,mother;
mother=b*d;//分母部分
if(s=='+')//分子部分
son=a*d+b*c;
else if(s=='-')
son=a*d-b*c;
if(son%mother==0)
printf("%d\n",son/mother);
else
{
int daughter=son>=0?son:-son;
son/=gcd(daughter,mother);
mother/=gcd(daughter,mother);
printf("%d/%d\n",son,mother);
}
}
return 0;
}