本题要求编写程序,计算 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. Javascript中的apply与call

    一丶定义 每个函数都包含两个非继承而来的方法:apply()和call().这两个方法的用途都是在特定的作用域中调用函数,实际上等于设置函数体内this对象的值. 1.apply()方法 apply( ...

  2. ios上表单默认样式

    摘自:http://blog.sina.com.cn/s/blog_7d796c0d0102uyd2.html 可惜不能直接转到博客园. input[type="button"], ...

  3. 有一分数序列:2/1, 3/2, 5/3, 8/5, 13/8, 21/13....求出这个数列的第M到N项之和(M>2,N>2,N>M)

    package bianchengti; /* * 有一分数序列:2/1, 3/2, 5/3, 8/5, 13/8, 21/13.... * 求出这个数列的第M到N项之和(M>2,N>2, ...

  4. Django模板之认证机制(csrf_token)

    csrf认证机制: django中对POST请求,csrf会进行认证处理,csrf认证机制是防御跨站伪造功能,在没有任何处理的前提下,POST请求会报错. csrf认证中间件是在process_vie ...

  5. Windows Terminal安装并美化

    介绍 Windows Teminal是一款新式.快速.高效.强大的终端应用程序,适用于命令行工具.命令提示符.PowerShell.WSL(Linux子系统)等等的Shell用户,主要功能包括多选项卡 ...

  6. Lowest Common Multiple Plus(hdu2028)

    思考: 乘法爆咋数据.把int换成unsigned就过了,同时%d换成%u.求最大公约数和最小公倍数. #include<stdio.h> int gcd(unsigned x, unsi ...

  7. python之module 'unittest' has no attribute 'TestCase' 解决方案

    脚本报错如下:  解决方案: 这是脚本名称冲突所导致的报错,修改脚本名中重新执行,运行正常 注:脚本取名最好不要与模块和方法一致,避免不必要的冲突

  8. Layui 解决动态图标不动的问题

    <i class="layui-icon layui-icon-face-smile" style="color: red; font-size: 100px;&q ...

  9. SEPC:使用3D卷积从FPN中提取尺度不变特征,涨点神器 | CVPR 2020

    论文提出PConv为对特征金字塔进行3D卷积,配合特定的iBN进行正则化,能够有效地融合尺度间的内在关系,另外,论文提出SEPC,使用可变形卷积来适应实际特征间对应的不规律性,保持尺度均衡.PConv ...

  10. js中 addEventListener 和removeEventListener

    js中添加事件监听本来是非常常见的事情,但是去除监听一般很少去干,最近项目中需要监听页面显示或者隐藏 代码如下 document.addEventListener(visibilitychange', ...