7-33 有理数加法

本题要求编写程序,计算两个有理数的和。

输入格式:

输入在一行中按照a1/b1 a2/b2的格式给出两个分数形式的有理数,其中分子和分母全是整形范围内的正整数。

输出格式:

在一行中按照a/b的格式输出两个有理数的和。注意必须是该有理数的最简分数形式,若分母为1,则只输出分子。

输入样例1:

1/3 1/6

输出样例1:

1/2

输入样例2:

4/3 2/3

输出样例2:

2

Python代码:

# 欧几里得算法求最大公约数
def gcd(m, n) -> int:
    left = m % n
    while left > 0:
        m = n
        n = left
        left = m % n
    return n


x, y = input().split()
a1, b1 = map(int, x.split('/'))
a2, b2 = map(int, y.split('/'))
b = int(b1 * b2 / gcd(b1, b2))  # 通分
a1 *= b2 / gcd(b1, b2)          # 通分
a2 *= b1 / gcd(b1, b2)          # 通分
a = int(a1 + a2)                # 需要转成int类型,不然有小数点

if a % b == 0:
    print((a / b).__round__())  # __round__()函数可以控制保留的小数点位数,参数默认为0
else:
    temp = gcd(a, b)
    print('%d/%d' % (a / temp, b / temp))

Python3支持函数类型注解

语法格式为在形参表和冒号之间加上 "-> 返回的类型"

^_^

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值