本题要求编写程序,计算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

分析:func(m, n)的作用是对m/n的分数进行化简,gcd(t1, t2)的作用是计算t1和t2的最大公约数~在func函数中,先看m和n里面是否有0(即m*n是否等于0),如果分母n=0,输出Inf,如果分子m=0,输出"0"~flag表示m和n是否异号,flag=true表示后面要添加负号"(-"和括号")",再将m和n都转为abs(m)和abs(n),即取他们的正数部分方便计算~x = m/n为m和n的可提取的整数部分,先根据flag的结果判断是否要在前面追加"(-",然后根据x是否等于0判断要不要输出这个整数位,接着根据m%n是否等于0的结果判断后面还有没有小分数,如果m能被n整除,表示没有后面的小分数,那么就根据flag的结果判断要不要加")",然后直接return~如果有整数位,且后面有小分数,则要先输出一个空格,接着处理剩下的小分数,先把m分子减去已经提取出的整数部分,然后求m和n的最大公约数t,让m和n都除以t进行化简~最后输出“m/n”,如果flag==true还要在末尾输出")"

注意:判断m和n是否异号千万不要写成判断m*n是否小于0,因为m*n的结果可能超过了long long int的长度,导致溢出大于0,如果这样写的话会有一个测试点无法通过~((⊙o⊙)嗯为了这一个测试点找bug找到凌晨两三点的就是我...我好菜啊.jpg)

#include <iostream>
#include <cmath>
using namespace std;
long long a, b, c, d;
long long gcd(long long t1, long long t2) {return t2 == 0 ? t1 : gcd(t2, t1 % t2);
}
void func(long long m, long long n) {if (m * n == 0) {printf("%s", n == 0 ? "Inf" : "0");return ;}bool flag = ((m < 0 && n > 0) || (m > 0 && n < 0));m = abs(m); n = abs(n);long long x = m / n;printf("%s", flag ? "(-" : "");if (x != 0) printf("%lld", x);if (m % n == 0) {if(flag) printf(")");return ;}if (x != 0) printf(" ");m = m - x * n;long long t = gcd(m, n);m = m / t; n = n / t;printf("%lld/%lld%s", m, n, flag ? ")" : "");
}
int main() {scanf("%lld/%lld %lld/%lld", &a, &b, &c, &d);func(a, b); printf(" + "); func(c, d); printf(" = "); func(a * d + b * c, b * d); printf("\n");func(a, b); printf(" - "); func(c, d); printf(" = "); func(a * d - b * c, b * d); printf("\n");func(a, b); printf(" * "); func(c, d); printf(" = "); func(a * c, b * d); printf("\n");func(a, b); printf(" / "); func(c, d); printf(" = "); func(a * d, b * c);return 0;
}

1034. 有理数四则运算(20)-PAT乙级真题相关推荐

  1. PAT 1074. 宇宙无敌加法器(20)-PAT乙级真题

    地球人习惯使用十进制数,并且默认一个数字的每一位都是十进制的.而在PAT星人开挂的世界里,每个数字的每一位都是不同进制的,这种神奇的数字称为"PAT数".每个PAT星人都必须熟记各 ...

  2. 1057. 数零壹(20)-PAT乙级真题

    1057. 数零壹(20) 给定一串长度不超过10^5的字符串,本题要求你将其中所有英文字母的序号(字母a-z对应序号1-26,不分大小写)相加,得到整数N,然后再分析一下N的二进制表示中有多少0.多 ...

  3. PAT 1072. 开学寄语(20)-PAT乙级真题

    1072. 开学寄语(20) 下图是上海某校的新学期开学寄语:天将降大任于斯人也,必先删其微博,卸其QQ,封其电脑,夺其手机,收其ipad,断其wifi,使其百无聊赖,然后,净面.理发.整衣,然后思过 ...

  4. 1064. 朋友数(20)-PAT乙级真题

    1064. 朋友数(20) 如果两个整数各位数字的和是一样的,则被称为是"朋友数",而那个公共的和就是它们的"朋友证号".例如123和51就是朋友数,因为1+2 ...

  5. 1063. 计算谱半径(20)-PAT乙级真题

    1063. 计算谱半径(20) 在数学中,矩阵的"谱半径"是指其特征值的模集合的上确界.换言之,对于给定的n个复数空间的特征值{a1+b1i, ..., an+bni},它们的模为 ...

  6. 1062. 最简分数(20)-PAT乙级真题

    1062. 最简分数(20) 一个分数一般写成两个整数相除的形式:N/M,其中M不为0.最简分数是指分子和分母没有公约数的分数表示形式. 现给定两个不相等的正分数 N1/M1 和 N2/M2,要求你按 ...

  7. 1007. 素数对猜想 (20)-PAT乙级真题

    让我们定义 dn 为:dn = pn+1 – pn,其中 pi 是第i个素数.显然有 d1=1 且对于n>1有 dn 是偶数."素数对猜想"认为"存在无穷多对相邻且 ...

  8. 1012. 数字分类 (20)-PAT乙级真题

    给定一系列正整数,请按要求对数字进行分类,并输出以下5个数字: A1 = 能被5整除的数字中所有偶数的和: A2 = 将被5除后余1的数字按给出顺序进行交错求和,即计算n1-n2+n3-n4-: A3 ...

  9. 1032. 挖掘机技术哪家强(20)-PAT乙级真题

    为了用事实说明挖掘机技术到底哪家强,PAT组织了一场挖掘机技能大赛.现请你根据比赛结果统计出技术最强的那个学校. 输入格式 输入在第1行给出不超过10^5的正整数N,即参赛人数.随后N行,每行给出一位 ...

最新文章

  1. codevs——1576 最长严格上升子序列(序列DP)
  2. C++ GUI Programming with Qt 3安装说明
  3. 70后、80后、90后程序员区别极端版
  4. A different twist on pre-compiling JSPs--reference
  5. Swing开发界面时的一个bug复盘
  6. P3545HUR-Warehouse StoreP4053建筑抢修(反悔贪心、堆)
  7. 学校计算机二级模拟上机能看分数吗,全国计算机二级考试机试考完怎么储存的...
  8. HDU 1027 G - Can you answer these queries?
  9. Varnish 缓存
  10. iOS The run destination iPhone is not valid for Running the scheme ‘项目名‘
  11. Gnu Screen用法 【转】
  12. Linux 下制作虚拟软盘镜像
  13. 医院职工离职申请证明模板,共计10篇
  14. np.minimum()与tf.minimum()的用法
  15. android显示微博sdk,android微博sdk发图文微博图片不显示35
  16. Dataframe两个表格合并
  17. 【KALI使用】14 被动信息收集——RECON-NG(待完善
  18. 10种算法一文打尽!基本图表算法的视觉化阐释
  19. 微信小程序Vant Weapp里面Calendar 日历组件不显示的问题
  20. 2012年10月显卡性能天梯图

热门文章

  1. 十个让你变成糟糕的程序员的行为
  2. dom4j处理XML的一些经验
  3. Unity AssetBundle 踩坑记录
  4. Android okHttp网络请求之缓存控制Cache-Control
  5. 【BZOJ 2301】[HAOI2011]Problem b
  6. oracle 用户表、字段信息
  7. FreeBSD6.1学习笔记[转]
  8. 轻松查看网页源代码-BlazingTool Instant Source软件的使用
  9. 黑客购买恶意软件攻击航空航天和交通行业,潜伏5年+
  10. 谷歌Linux基金会等联合推出开源软件签名服务 sigstore,提振软件供应链安全