PAT 有理数四则运算
本题要求编写程序,计算 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 有理数四则运算的更多相关文章
- PAT (Basic Level) Practise (中文)-1034. 有理数四则运算(20)
PAT (Basic Level) Practise (中文)-1034. 有理数四则运算(20) http://www.patest.cn/contests/pat-b-practise/1034 ...
- PAT 1034 有理数四则运算(20)(代码框架+思路+测试点错误分析)
1034 有理数四则运算(20)(20 分)提问 本题要求编写程序,计算2个有理数的和.差.积.商. 输入格式: 输入在一行中按照"a1/b1 a2/b2"的格式给出两个分数形式的 ...
- PAT(B) 1034 有理数四则运算(Java)
题目链接:1034 有理数四则运算 (20 point(s)) 题目描述 本题要求编写程序,计算 2 个有理数的和.差.积.商. 输入格式 输入在一行中按照 a1/b1 a2/b2 的格式给出两个分数 ...
- PAT-乙级-1034. 有理数四则运算(20)
1034. 有理数四则运算(20) 时间限制 200 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 本题要求编写程序,计算2个有理 ...
- 用java具体代码实现分数(即有理数)四则运算
用java具体代码实现分数(即有理数)四则运算 1,背景 Java老师布置了一个关于有理数运算的题目,因为参考书上有基本代码,所以自己主要是对书上代码做了一点优化,使其用户交互性更加友好以及代码封装性 ...
- 【算法笔记】B1034 有理数四则运算
1034 有理数四则运算 (20 分) 本题要求编写程序,计算 2 个有理数的和.差.积.商. 输入格式: 输入在一行中按照 a1/b1 a2/b2 的格式给出两个分数形式的有理数,其中分子和分母 ...
- P 1034 有理数四则运算
转跳点:
- PAT1034 有理数四则运算 (20分)
1034 有理数四则运算 (20分) 本题要求编写程序,计算 2 个有理数的和.差.积.商. 输入格式: 输入在一行中按照 a1/b1 a2/b2 的格式给出两个分数形式的有理数,其中分子和分母全 ...
- PAT 1034. 有理数四则运算(20)
本题要求编写程序,计算2个有理数的和.差.积.商. 输入格式: 输入在一行中按照"a1/b1 a2/b2"的格式给出两个分数形式的有理数,其中分子和分母全是整型范围内的整数,负号只 ...
随机推荐
- 给出两个单词(start和end)与一个字典,找出从start到end的最短转换序列
问题 给出两个单词(start和end)与一个字典,找出从start到end的最短转换序列.规则如下: 一次只能改变一个字母 中间单词必须在字典里存在 例如: 给出 start = "hit ...
- PHP EOF使用说明
PHP EOF(heredoc) 使用说明 PHP EOF(heredoc)是一种在命令行shell(如sh.csh.ksh.bash.PowerShell和zsh)和程序语言(像Perl.PHP.P ...
- .Net Core3.0 WebApi 项目框架搭建 五: 轻量型ORM+异步泛型仓储
.Net Core3.0 WebApi 项目框架搭建:目录 SqlSugar介绍 SqlSugar是国人开发者开发的一款基于.NET的ORM框架,是可以运行在.NET 4.+ & .NET C ...
- class.getFields和class.getDeclareFields的区别
class.getFields的定义 返回类提供的public域包括超类的共有变量; 注: 是public,我们平时定义变量一般用的private,如果用getFields是不会获得. class.g ...
- Jquery动画,排队与并发
一.事件绑定 1.鼠标事件:模拟触发 什么是模拟触发? 虽然没有点在按钮上,也可以触发按钮的事件处理函数. 如何:$元素.trigger("事件名") 即使没有点在指定的元素上,也 ...
- 第几天?(hdu2005)
第几天那个代码模板可以保存起来. #include<stdio.h> #include<math.h> #define PI 3.1415927 using namespace ...
- python+selenium 自动化测试框架-学习记录
本人小白一枚,想着把学习时的东西以博客的方式记录下来,文章中有不正确的地方请大佬多多指点!!共同学习 前期准备 安装python3.selenium.下载对应版本的webdriver:安装所需的第三 ...
- 【持续更新】springboot相关配置
@Configuration public class MyWebMvcConfig implements WebMvcConfigurer { //注册了新的访问路径 @Override publi ...
- Maven快速入门(一)Maven介绍及环境搭建
做开发的程序员都知道,在系统开发需要各自各样的框架.工具.其中有一种工具不管你是初级程序员还是高级程序员都必须熟练掌握的,那就是项目管理工具(maven.ant.gradle).接下来就总结Maven ...
- Robot Framework(12)- 详细解读 RF 的变量和常量
如果你还想从头学起Robot Framework,可以看看这个系列的文章哦! https://www.cnblogs.com/poloyy/category/1770899.html 常量的栗子 常量 ...