本题要求编写程序,计算 2 个有理数的和、差、积、商。
输入格式:
输入在一行中按照 a1/b1 a2/b2
的格式给出两个分数形式的有理数,其中分子和分母全是整型范围内的整数,负号只可能出现在分子前,分母不为 0。
输出格式:
分别在 4 行中按照 有理数1 运算符 有理数2 = 结果
的格式顺序输出 2 个有理数的和、差、积、商。注意输出的每个有理数必须是该有理数的最简形式 k a/b
,其中 k
是整数部分,a/b
是最简分数部分;若为负数,则须加括号;若除法分母为 0,则输出 Inf
。题目保证正确的输出中没有超过整型范围的整数。
输入样例 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
思路:设计一个函数专门打印分数,然后加减乘除根据分数方式处理即可,数据定义为长整型更好处理,
我发现数据都AC有问题,有一种情况没考虑,就是a1/b1=0,a2/b=负数时,这个没考虑 也会通过
#include <iostream>
#include <stdio.h>
#include <stdlib.h>
#define LL long long
int add(LL a1,LL b1,LL a2,LL b2);//加
int minu(LL a1,LL b1,LL a2,LL b2);//减
int multi(LL a1,LL b1,LL a2,LL b2);//乘
int divide(LL a1,LL b1,LL a2,LL b2);//除
int num(LL a,LL b);//打印分数
LL gcd(LL a,LL b);//求最大公约数
int main( )
{
LL a1,b1,a2,b2;//输入的时候是整形,但是相乘之后可能出现长整型
scanf("%lld/%lld %lld/%lld",&a1,&b1,&a2,&b2);
add(a1,b1,a2,b2);
minu(a1,b1,a2,b2);
multi(a1,b1,a2,b2);
divide(a1,b1,a2,b2);
return 0;
}
int add(LL a1,LL b1,LL a2,LL b2)
{
num(a1,b1);
printf(" + ");
num(a2,b2);
printf(" = ");
num(a1*b2+a2*b1,b2*b1);//分数加法
printf("\n");
return 0;
}
int minu(LL a1,LL b1,LL a2,LL b2)
{
num(a1,b1);
printf(" - ");
num(a2,b2);
printf(" = ");
num(a1*b2-a2*b1,b2*b1);//分数减法
printf("\n");
return 0;
}
int multi(LL a1,LL b1,LL a2,LL b2)
{
num(a1,b1);
printf(" * ");
num(a2,b2);
printf(" = ");
num(a1*a2,b1*b2);//分数乘法
printf("\n");
return 0;
}
int divide(LL a1,LL b1,LL a2,LL b2)
{
num(a1,b1);
printf(" / ");
num(a2,b2);
printf(" = ");
if(a2==0)//分母为0,打印Inf
{
printf("Inf\n");
return 0;
}
num(a1*b2,b1*a2);//分数除法
printf("\n");
return 0;
}
int num(LL a,LL b)
{
int sign = 1;
LL getgcd;
//负负得正,如果分子为负,也就不用加负号
if (a < 0&& b!=0)
{
a = -a;
sign = sign * -1;
}
if (b < 0&& a!=0)
{
b = -b;
sign = sign * -1;
}
getgcd = gcd(a, b);//求最大公约数
a = a / getgcd;
b = b / getgcd;//化简
if (sign == -1) printf("(-");//判断符号
if(a%b==0)//整数
{
printf("%lld",a/b);
if(sign==-1)
printf(")");
return 0;
}
else
{
if(a/b)//带分数
{
printf("%lld ",a/b);
a=a%b;//真分数分子
}
printf("%lld/%lld",a,b);//真分数
if(sign==-1)//判断符号
printf(")");
return 0;
}
}
LL gcd(LL a,LL b)
{
if(b==0) return a;
else return gcd(b,a%b);
}