如题:http://www.patest.cn/contests/pat-b-practise/1034
本题要求编写程序,计算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
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
long long gcd(long long x,long long y)
{
if(y==0)
return x;
return gcd(y,x%y);
}
void format(long long a,long long b)
{
if(b==0)
{
cout<<"Inf";
return;
}
long long k;
long long yue=gcd(abs(a),b);
a=a/yue;
b=b/yue;
k=a/b;
if(k!=0)
a=abs(a)%b;
if(k==0&&a==0)
{
cout<<0;
}
else if(k==0&&a>0)
{
if(b==1)
cout<<a;
else
cout<<a<<"/"<<b;
}
else if(k==0&&a<0)
{
if(b==1)
cout<<"("<<a<<")";
else
cout<<"("<<a<<"/"<<b<<")";
}
else if(k>0&&a==0)
{
cout<<k;
}
else if(k>0&&a!=0)
{
if(b==1)
cout<<k<<" "<<a;
else
cout<<k<<" "<<a<<"/"<<b;
}
else if(k<0&&a==0)
{
cout<<"("<<k<<")";
}
else if(k<0&&a!=0)
{
if(b==1)
cout<<"("<<k<<" "<<a<<")";
else
cout<<"("<<k<<" "<<a<<"/"<<b<<")";
}
}
void print(long long a1,long long b1,long long a2,long long b2,char ch)
{
format(a1,b1);
printf(" %c ",ch);
format(a2,b2);
cout<<" = ";
long long a,b;
if(ch=='+')
{
a=a1*b2+a2*b1;
b=b1*b2;
format(a,b);
}
else if(ch=='-')
{
a=a1*b2-a2*b1;
b=b1*b2;
format(a,b);
}
else if(ch=='*')
{
a=a1*a2;
b=b1*b2;
format(a,b);
}
else
{
a=a1*b2;
b=b1*a2;
if(b<0)
{
b*=-1;
a*=-1;
}
format(a,b);
}
cout<<endl;
}
int main()
{
// freopen("C:\\1.txt","r",stdin);
long long a1,b1,a2,b2; //a1/b1 a2/b2
scanf("%lld/%lld %lld/%lld", &a1, &b1, &a2, &b2);
print(a1,b1,a2,b2,'+');
print(a1,b1,a2,b2,'-');
print(a1,b1,a2,b2,'*');
print(a1,b1,a2,b2,'/');
}