PAT (Basic Level) Practise (中文)-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 分析:本题目没有思维的难度,只是可能处理起来有点啰嗦烦人,所以建议一定要单独写成小功能函数。
比如:
1. 输出的每个有理数必须是该有理数的最简形式“k a/b”,其中k是整数部分,a/b是最简分数部分
2. 若为负数,则须加括号
3. 若除法分母为0,则输出“Inf”。
 #include<stdio.h>

     void jianhua(long long  *fenzi,long long  *fenmu)
{
if(*fenzi== || *fenmu==)
{
*fenzi=,*fenmu=;
return;
} int flag1=,flag2= ;// 1负数 2正数
if(*fenzi<) flag1=,*fenzi=-*fenzi;
if(*fenmu<) flag2=,*fenmu=-*fenmu; long long max=,min=;
if(*fenzi>*fenmu) max=*fenzi,min=*fenmu;
else min=*fenzi,max=*fenmu;
while(max%min)
{
if(max-min>min)
max=max-min;
else
{
min=max-min;
max=max-min;
}
}
*fenzi/=min,*fenmu/=min; if(flag1) *fenzi=-*fenzi;
if(flag2) *fenmu=-*fenmu;
if(*fenmu<) *fenzi=-*fenzi,*fenmu=-*fenmu; return;
} void outlook(long long a,long long b,int i,long long c) //输出 函数
{
int flag=;
if(a<) {flag=;a=-a;printf("(-");} if(i== && c==) printf("Inf"); //i==3时代表除法运算
else if(a==) printf(""); //分子为0,即数==0
else if(a/b) { if(a%b) printf("%lld %lld/%lld",a/b,a%b,b);
else printf("%lld",a/b);
}else printf("%lld/%lld",a,b); //可以整除,即简化为整数 if(flag) printf(")");
} int main()
{
long long *pfenzi=,*pfenmu=;
long long a=,b=,c=,d=,fenzi=,fenmu=; //因为两个整数相乘,可能超出int范围,所以使用了long long
scanf("%lld/%lld %lld/%lld",&a,&b,&c,&d); pfenzi=&a;
pfenmu=&b;
jianhua(pfenzi,pfenmu); //第一个数
pfenzi=&c;
pfenmu=&d;
jianhua(pfenzi,pfenmu); //第二个数
char op[]={'+','-','*','/'};
for(int i=;i<;i++)
{
//'+','-','*','/' 依次处理
if(==i) { fenzi=a*d+c*b; fenmu=b*d; }
else if(==i) { fenzi=a*d-c*b; fenmu=b*d; }
else if(==i) { fenzi=a*c; fenmu=b*d; }
else { fenzi=a*d; fenmu=b*c; }
pfenzi=&fenzi;
pfenmu=&fenmu;
jianhua(pfenzi,pfenmu); // 简化当前处理运算的结果 // 格式输出
if(i) printf("\n");
outlook(a,b,i,); //第一个数
printf(" %c ",op[i]); // 运算符
outlook(c,d,i,); //第二个数
printf(" = ");
outlook(fenzi,fenmu,i,c); //结果
} return ;
}

好讨厌这道题。。。难度不高,却这么复杂。。。好考验耐心。。。

												

PAT (Basic Level) Practise (中文)-1034. 有理数四则运算(20)的更多相关文章

  1. PAT (Basic Level) Practise (中文)-1039. 到底买不买(20)

    PAT (Basic Level) Practise (中文)-1039. 到底买不买(20) http://www.patest.cn/contests/pat-b-practise/1039 小红 ...

  2. PAT (Basic Level) Practise (中文)- 1022. D进制的A+B (20)

    PAT (Basic Level) Practise (中文)-  1022. D进制的A+B (20)  http://www.patest.cn/contests/pat-b-practise/1 ...

  3. PAT (Basic Level) Practise (中文)- 1024. 科学计数法 (20)

    PAT (Basic Level) Practise (中文)- 1024. 科学计数法 (20) http://www.patest.cn/contests/pat-b-practise/1024 ...

  4. PAT (Basic Level) Practise (中文)-1025. 反转链表 (25)

    PAT (Basic Level) Practise (中文)-1025. 反转链表 (25)   http://www.patest.cn/contests/pat-b-practise/1025 ...

  5. PAT (Basic Level) Practise (中文)- 1026. 程序运行时间(15)

    PAT (Basic Level) Practise (中文)- 1026. 程序运行时间(15)    http://www.patest.cn/contests/pat-b-practise/10 ...

  6. PAT (Basic Level) Practise (中文)-1027. 打印沙漏(20)

    PAT (Basic Level) Practise (中文)-1027. 打印沙漏(20)  http://www.patest.cn/contests/pat-b-practise/1027 本题 ...

  7. PAT (Basic Level) Practise (中文)-1028. 人口普查(20)

    PAT (Basic Level) Practise (中文)-1028. 人口普查(20)   http://www.patest.cn/contests/pat-b-practise/1028 某 ...

  8. PAT (Basic Level) Practise (中文)-1029. 旧键盘(20)

    PAT (Basic Level) Practise (中文)-1029. 旧键盘(20) http://www.patest.cn/contests/pat-b-practise/1029 旧键盘上 ...

  9. PAT (Basic Level) Practise (中文)-1030. 完美数列(25)

    PAT (Basic Level) Practise (中文)-1030. 完美数列(25)   http://www.patest.cn/contests/pat-b-practise/1030 给 ...

随机推荐

  1. Swift3.0 轮播图

    使用三个UIButton实现无限轮播:https://github.com/LXfeiYu/LXCarouselImages.git 喜欢的朋友给个星!!! 功能: 1.可以选择开启和关闭定时器 2. ...

  2. C#、Unity网络通信中基于字节码的自定义协议解码,C#版ByteBuffer

    http://www.oschina.net/code/snippet_42170_37516 C#.Unity基于字节的网络通信中字节码解析类,类似java中的ByteBuffer,不过这个实现是参 ...

  3. 洛谷P3723 [AH2017/HNOI2017]礼物(FFT)

    传送门 首先,两个数同时增加自然数值相当于只有其中一个数增加(此增加量可以小于0) 我们令$x$为当前的增加量,${a},{b}$分别为旋转后的两个数列,那么$$ans=\sum_{i=1}^n(a_ ...

  4. JDK1.7 和 jetty配置教程

    系统是windows 7 64位版本,32位版本同理,xp系统的自己google设置环境变量 打开设置环境变量窗口,右键计算机->我的电脑,选择属性 点击高级系统设置 选择环境变量 红线为需要设 ...

  5. 买票案例 1.synchronize关键字 2.lock锁

  6. queue模块

    queue队列 :使用import queue,用法与进程Queue一样 queue is especially useful in threaded programming when informa ...

  7. Codeforces 1107F(dp)

    怎么就没人解释一下为啥用b排序可以保证正确性呢……太菜了,理解了好久. 时间流逝价值会丢失的背包,类似题洛谷1417 本题与洛谷1417不同之处在于流逝是有截止的. 1.这个dp[j]的含义是:最后跑 ...

  8. 洛谷 P1067 多项式输出

    P1067 多项式输出 模拟,很坑的那种 var i,n:longint; a:array[1..105] of integer; begin readln(n); for i:=1 to n+1 d ...

  9. layer窗口抖动

    详细学习网址 http://www.layui.com/doc/modules/layer.html#use ..................................... //使用方法 ...

  10. aspx页面调用webapi接口报错:远程服务器返回错误:(500)内部服务器错误

    代码在运行到response = (HttpWebResponse)request.GetResponse();就开始报错 原因:可能因为所调用的接口不存在或者接口中存在错误,可用postman测试接 ...