本题要求编写程序,计算 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
#将输入的两个分数和计算的结果转化成题目要求的最简形式
def hjian(fenshu):
a, b = fenshu.split('/')
fenzi = int(a) # 分子
fenmu = int(b) # 分母
mcg=zd(fenzi,fenmu)
fenzi//=mcg
fenmu//=mcg
z = fenzi // fenmu # 整数部分
f = fenzi % fenmu # 分数部分的分子
if fenzi == 0:
return ''
elif z and f == 0:
return str(z)
elif z == 0 and f:
return str(f) + '/' + str(fenmu)
elif z and f:
return str(z) + ' ' + str(f) + '/' + str(fenmu)
#返回x和y的最大公因数
def zd(x,y):
if x<y:
x,y=y,x
while y!=0:
n=x%y
x,y=y,n
return x
a, b = input().strip().split()
aa0,aa1=int(a.split('/')[0]),int(a.split('/')[1])
bb0,bb1=int(b.split('/')[0]),int(b.split('/')[1])
abz,abm=aa0*bb1+aa1*bb0,aa1*bb1
ab=str(abz)+'/'+str(abm) # a+b
ajbz=aa0*bb1-aa1*bb0
ajb=str(ajbz)+'/'+str(abm) # a-b
acbz=aa0*bb0
acb=str(acbz)+'/'+str(abm) # a*b
aa,bb,cc,dd,ee,ff='','','','','',''
if a[0] != '-':
aa=hjian(a)
else:
aa=hjian(a[1:])
aa='('+'-'+aa+')'
if ab[0]!='-':
cc=hjian(ab)
else:
ab=hjian(ab[1:])
cc='('+'-'+ab+')'
if ajb[0]!='-':
dd=hjian(ajb)
else:
ajb=hjian(ajb[1:])
dd='('+'-'+ajb+')'
if acb[0]!='-':
ee=hjian(acb)
else:
acb=hjian(acb[1:])
ee='('+'-'+acb+')'
if b[0]!='-':
bb=hjian(b)
else:
bb=hjian(b[1:])
bb='('+'-'+bb+')'
# print(aa,bb)
print(aa+' '+'+'+' '+bb+' '+'='+' '+cc)
print(aa+' '+'-'+' '+bb+' '+'='+' '+dd)
print(aa+' '+'*'+' '+bb+' '+'='+' '+ee)
ahb=''
#除法除数为0的情况
if bb=='':
print(aa+' '+'/'+' '+bb+' '+'='+' '+'Inf')
else:
ahbz=aa0*bb1
ahbm=aa1*bb0
#如果除数为负,则做除法时,乘除数的倒数,会把符号放到分母上,所以,需要处理一下
if ahbm<0:
if ahbz<0:
ahb=str(abs(ahbz))+'/'+str(abs(ahbm))
else:
ahb=str(0-ahbz)+'/'+str(abs(ahbm))
else:
ahb=str(ahbz)+'/'+str(ahbm)
if ahb[0]!='-':
ff=hjian(ahb)
else:
ahb=hjian(ahb[1:])
ff='('+'-'+ahb+')'
print(aa+' '+'/'+' '+bb+' '+'='+' '+ff)

全程稀里糊涂,写了这么多行,快看晕了,终于我把Python代码的优雅和简洁全扔掉了,确实写的很臃肿

PAT 有理数四则运算的更多相关文章

  1. PAT (Basic Level) Practise (中文)-1034. 有理数四则运算(20)

    PAT (Basic Level) Practise (中文)-1034. 有理数四则运算(20)  http://www.patest.cn/contests/pat-b-practise/1034 ...

  2. PAT 1034 有理数四则运算(20)(代码框架+思路+测试点错误分析)

    1034 有理数四则运算(20)(20 分)提问 本题要求编写程序,计算2个有理数的和.差.积.商. 输入格式: 输入在一行中按照"a1/b1 a2/b2"的格式给出两个分数形式的 ...

  3. PAT(B) 1034 有理数四则运算(Java)

    题目链接:1034 有理数四则运算 (20 point(s)) 题目描述 本题要求编写程序,计算 2 个有理数的和.差.积.商. 输入格式 输入在一行中按照 a1/b1 a2/b2 的格式给出两个分数 ...

  4. PAT-乙级-1034. 有理数四则运算(20)

    1034. 有理数四则运算(20) 时间限制 200 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 本题要求编写程序,计算2个有理 ...

  5. 用java具体代码实现分数(即有理数)四则运算

    用java具体代码实现分数(即有理数)四则运算 1,背景 Java老师布置了一个关于有理数运算的题目,因为参考书上有基本代码,所以自己主要是对书上代码做了一点优化,使其用户交互性更加友好以及代码封装性 ...

  6. 【算法笔记】B1034 有理数四则运算

    1034 有理数四则运算 (20 分)   本题要求编写程序,计算 2 个有理数的和.差.积.商. 输入格式: 输入在一行中按照 a1/b1 a2/b2 的格式给出两个分数形式的有理数,其中分子和分母 ...

  7. P 1034 有理数四则运算

    转跳点:

  8. PAT1034 有理数四则运算 (20分)

    1034 有理数四则运算 (20分)   本题要求编写程序,计算 2 个有理数的和.差.积.商. 输入格式: 输入在一行中按照 a1/b1 a2/b2 的格式给出两个分数形式的有理数,其中分子和分母全 ...

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

    本题要求编写程序,计算2个有理数的和.差.积.商. 输入格式: 输入在一行中按照"a1/b1 a2/b2"的格式给出两个分数形式的有理数,其中分子和分母全是整型范围内的整数,负号只 ...

随机推荐

  1. 1026 Table Tennis (30分) 难度不高 + 逻辑复杂 +细节繁琐

    题目 A table tennis club has N tables available to the public. The tables are numbered from 1 to N. Fo ...

  2. 学习ASP.NET Core(06)-Restful与WebAPI

    上一篇我们使用Swagger添加了接口文档,使用Jwt完成了授权,本章我们简答介绍一下RESTful风格的WebAPI开发过程中涉及到的一些知识点,并完善一下尚未完成的功能 .NET下的WebAPI是 ...

  3. webpack使用babel

    几个月没用webpack都忘了好多了. webpack构建前端,使用时除了entry/output,就是plugins和module.loaders,还有本地测试的devServer. npm ins ...

  4. Problem 2232 炉石传说

    Problem 2232 炉石传说 不知道fzu的账号在哪里弄,想要做题的可以到vj上面去做 https://vjudge.net/problem/FZU-2232 #include <iost ...

  5. Java的每个Thread都希望拥有自己的名称

    一. 介绍 平时工作中可能会碰到排查多线程的bug,而在排查的时候,如果线程(单个线程或者是线程池的线程)没有一个比较明确的名称,那么在排查的时候就比较头疼,因为排查问题首先需要找出“问题线程”,如果 ...

  6. 【python 爬虫】fake-useragent Maximum amount of retries reached解决方案

    前言 在用fake-useragent的时候发生报错,fake_useragent.errors.FakeUserAgentError: Maximum amount of retries reach ...

  7. Mysql与Mysqli的区别及特点

    1)PHP-MySQL 是 PHP 操作 MySQL 资料库最原始的 Extension ,PHP-MySQLi 的 i 代表 Improvement ,提更了相对进阶的功能,就 Extension ...

  8. layui table 数据表格固定列的行高和table其他列的行高不一致

    1.问题描述:使用layui的table数据表格,固定某一列,这样表格中数据的宽度超出屏幕宽度时,固定列可以一直显示在屏幕中,不会随着底部滚动栏左右的拖动而变化位置.但是遇到一个问题,就是固定列的行高 ...

  9. 关于mantisBT2.22安装插件Inline column configuration 2.0.0时提示缺少依赖jQuery UI Library 1.8

    1.首先直接下载最新的那个1.12即可 https://github.com/mantisbt-plugins/jQuery-UI/releases 2.上传到mantis的插件目录下:……manti ...

  10. 剑指Offer之矩形覆盖

    题目描述 我们可以用2*1的小矩形横着或者竖着去覆盖更大的矩形.请问用n个2*1的小矩形无重叠地覆盖一个2*n的大矩形,总共有多少种方法? 比如n=3时,2*3的矩形块有3种覆盖方法: 思路:与裴波拉 ...