本题要求编写程序,计算 2 个有理数的和、差、积、商。
输入格式:
输入在一行中按照 a1/b1 a2/b2
的格式给出两个分数形式的有理数,其中分子和分母全是整型范围内的整数,负号只可能出现在分子前,分母不为 0。
输出格式:
分别在 4 行中按照 有理数1 运算符 有理数2 = 结果
的格式顺序输出 2 个有理数的和、差、积、商。注意输出的每个有理数必须是该有理数的最简形式 k a/b
,其中 k
是整数部分,a/b
是最简分数部分;若为负数,则须加括号;若除法分母为 0,则输出 Inf
。题目保证正确的输出中没有超过整型范围的整数。
样例-1:">样例-1:">样例-1:">样例-1:">输入样例 1:
2/3 -4/2
输出样例 1:
2/3 + (-2) = (-1 1/3)
2/3 - (-2) = 2 2/3
2/3 * (-2) = (-1 1/3)
2/3 / (-2) = (-1/3)
输入样例 2:
5/3 0/6
输出样例 2:
1 2/3 + 0 = 1 2/3
1 2/3 - 0 = 1 2/3
1 2/3 * 0 = 0
1 2/3 / 0 = Inf
思路
1、重要的是格式输出的函数的编写,思路为全按正数进行输出,若是负数的话,在前后加上括号即可。
2、“题目保证正确的输出中没有超过整型范围的整数”,int型过不了测试点,乘法计算容易超出范围,所以都改为long long型。
3、取绝对值时要用llabs(),不能用abs(),因为是long long型,不然测试点3过不了(之前找了好久的错,哭死)。
AC代码
#include<stdio.h>//abs的参数范围是int型,longlong型要用llabs,不然测试点过不了
#include<math.h>
long long gcd(long long a,long long b){//最大公约数
return b?gcd(b,a%b):a;
}
void shuchu(long long a,long long b){//按要求输出的函数
int f=0;
if((a<0&&b>0)||(a>0&&b<0))f=1;//以正数进行输出,若是负数则加括号即可
a=llabs(a);
b=llabs(b);
long long t=gcd(a,b);//约分为最简形式
a/=t;
b/=t;
if(f==1)printf("(-");//负数带括号
if(b==1)printf("%lld",a);
else if(a<b)printf("%lld/%lld",a,b);
else if(a>b)printf("%lld %lld/%lld",a/b,a%b,b);
if(f==1)printf(")");
}
int main(){
long long a1,b1,a2,b2,a,b,t;
scanf("%lld/%lld %lld/%lld",&a1,&b1,&a2,&b2);
//加法
shuchu(a1,b1);
printf(" + ");
shuchu(a2,b2);
printf(" = ");
shuchu(a1*b2+a2*b1,b1*b2);
printf("\n");
//减法
shuchu(a1,b1);
printf(" - ");
shuchu(a2,b2);
printf(" = ");
shuchu(a1*b2-a2*b1,b1*b2);
printf("\n");
//乘法
shuchu(a1,b1);
printf(" * ");
shuchu(a2,b2);
printf(" = ");
shuchu(a1*a2,b1*b2);
printf("\n");
//除法
shuchu(a1,b1);
printf(" / ");
shuchu(a2,b2);
printf(" = ");
if(a2==0)printf("Inf");//判断Inf
else shuchu(a1*b2,b1*a2);
return 0;
}