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"的格式给出两个分数形式的有理数,其中分子和分母全是整型范围内的整数,负号只 ...
随机推荐
- 09JAVA基础-常用类
1.Scanner //获取键盘输入 Scanner sc = new Scanner(System.in); int num = sc.nextIn(); String str = sc.nextL ...
- 存储过程——公用表表达式(CTE)
目录 0. 背景说明 1. 定义及语法细节 1.1 基本定义 1.2 基本语法 1.3 多个CTE同时声明 1.4 CTE嵌套使用 2. CTE递归查询 2.1 简介 2.2 准备工作 2.3 计算每 ...
- java经典问题 byte b=1、b=b+1、b+=1
直接问题: 首先 byte的范围 [-128,127] byte 类型可以自动转为int类型 int类型不能自动转为byte类型. 超过byte的范围,就会变成int类型了 byte b=1:正确, ...
- java方法调用顺序
public class JavalearningApplicationTests { static { System.out.println("Test的静态代码块"); } p ...
- flex布局学习总结--阮一峰
基本概念: 采用 Flex 布局的元素,称为 Flex 容器(flex container),简称"容器".它的所有子元素自动成为容器成员,称为 Flex 项目(flex it ...
- 使用naxsi
naxsi简介 naxsi 是一个nginx 防病毒,防跨站,sql 注入的一个模块.nginx的一个waf ,应用防火墙.非常好配置. naxsi 安装 naxsi 在debina/ubuntu 上 ...
- mysql安装之后需要调的参数
http://www.mysqlperformanceblog.com/2014/01/28/10-mysql-settings-to-tune-after-installation/ 翻译加深理解. ...
- Redux:store
Store是一个对象.他有如下职责: 1.存放state 2.对外提供访问state的接口: getState() 3.允许state更新:dispatch(action) 4.注册监听器: subs ...
- 输入一个整数n,输出契波那契数列的第n项
package bianchengti; /* * 输入一个整数n,输出契波那契数列的第n项 * 斐波那契数列:1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89... */ p ...
- Django模板之自定义过滤器/标签/组件
自定义步骤: 1. 在settings中的INSTALLED_APPS配置当前app,不然django无法找到自定义的simple_tag. 2. 在app应用中创建templatet ...