本题要求编写程序,计算 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. Tomcat在IDEA部署Web项目

    Tomcat在IDEA上部署Web项目: 一.新建Maven-Web项目: 1.新建项目,选择Maven,从模板中创建,选中web-app 2.选择项目地址: 3.选择配置的maven(如果按我之前写 ...

  2. 「雕爷学编程」Arduino动手做(22)——8X8 LED点阵MAX7219屏

    37款传感器与模块的提法,在网络上广泛流传,其实Arduino能够兼容的传感器模块肯定是不止37种的.鉴于本人手头积累了一些传感器和模块,依照实践出真知(一定要动手做)的理念,以学习和交流为目的,这里 ...

  3. MySQL 选错索引的原因?

    MySQL 中,可以为某张表指定多个索引,但在语句具体执行时,选用哪个索引是由 MySQL 中执行器确定的.那么执行器选择索引的原则是什么,以及会不会出现选错索引的情况呢? 先看这样一个例子: 创建表 ...

  4. webpack 3 升级 webpack4 个人笔记

    参考文章: 1. webpack4升级完全指南 https://segmentfault.com/a/1190000014247030 2. Mobx useStrict is not a funct ...

  5. js读取json

    Json字符串是: [{"n":"aaa","un":"aaa"},{"n":"yang& ...

  6. 架构设计 | 接口幂等性原则,防重复提交Token管理

    本文源码:GitHub·点这里 || GitEE·点这里 一.幂等性概念 1.幂等简介 编程中一个幂等操作的特点是其任意多次执行所产生的影响均与一次执行的影响相同.就是说,一次和多次请求某一个资源会产 ...

  7. POJ2991

    题目链接:https://vjudge.net/problem/POJ-2991 知识准备: 1.向量旋转公式:向量(x,y)逆时针旋转角度A,则旋转后的向量为(x*cos A-y*sin A, x* ...

  8. 【MySQL】索引的本质(B+Tree)解析

    索引是帮助MySQL高效获取数据的排好序的数据结构. 索引数据结构 二叉树 红黑树 Hash表 B-Tree MySQL所使用为B+Tree (B-Tree变种) 非叶子节点不存储data,只存储索引 ...

  9. idea的生成类注释和方法注释

    sttings中选择 类注释 /** * @program: ${PROJECT_NAME} * * @description: ${description} * * @author: xiaozha ...

  10. 对 getopts 的理解

    getopts 格式 1 #!/bin/bash 2 echo "begin index is $OPTIND" 3 echo "begin ARG is $OPTARG ...