问题遇到的现象和发生
求解惑,我的代码问题出在哪里,样例通过,但不对,请不要直接给代码,尽可能用原来代码思路,谢谢
分数加减法
任务描述
编写一个C程序,实现两个分数的加减法
输入格式:
输入包含多行数据。每行数据是一个字符串,格式是"a/boc/d"。 其中a, b, c, d是一个整数。o是运算符"+"或者"-"。输入数据保证合法。
输出格式:
对于输入的每一组数据(每一行)输出两个分数的运算结果。结果应化简至最简分数,并且如果是负值负号在最前面,如果是整数则只输出整数结果。
输入样例:
1/8--3/8
-1/-4--1/-2
1/3-1/3
1/3+2/3
输出样例:
1/2
-1/4
0
1
问题相关代码,请勿粘贴截图
#include <stdio.h>
int yue(int r1,int r2){//辗转相除最大公约
int c=r1%r2;
while(c!=0){
c=r1%r2;
r1=r2;
r2=c;
}
return r1;
}
int main()
{ int a,b,c,d,i,r1,r2,m=0,t;
char ch;
while(scanf("%d/%d%c%d/%d",&a,&b,&ch,&c,&d)!=EOF)
//a=1;b=3;ch='+';c=2;d=3;
{
a*=d;
c*=b;//通分
if(ch=='+')r1=a+c;
else r1=a-c;//分子运算
r2=b*d; //分母
//约分
if(r1==0){
printf("0\n");
continue;
}else if(r2==1){
printf("%d\n",r1);
continue;
}else if(r2==-1){
printf("%d\n",0-r1);
continue;
}else if(r2<0&&r1>0){
t=yue(r1,0-r2);//求分子分母绝对值的公约数
r1/=t;
r2/=t;
}else if(r1<0&&r2>0){
t=yue(0-r1,r2);//求分子分母绝对值的公约数
r1/=t;
r2/=t;
}else if(r1*r2>0){//分子分母同号
t=yue(r1,r2);
r1/=t;
r2/=t;
}
if(r2==1)printf("%d\n",r1);
else if(r2==-1){
printf("%d\n",0-r1);
}
else if(r2<0)//只要分母为负,当分子为正把负号移给分子,当分子为负整体为正,
{
printf("%d/%d\n",0-r1,0-r2);
}else
{
printf("%d/%d\n",r1,r2);
}
}
return 0;
}