1034. 有理数四则运算(20)

如题: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,'/');
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值