python实现高精度加法

有的时候由于两个相加的数字太大了,所以在相加的时候可能会出现溢出的情况,这个时候就可以使用高精度加法来解决这个问题。高精度加法主要使用数组或者列表来存储两个加数对应位置上的数字以及相加的结果(两个相加的数字太大所以一般使用字符串来表示两个加数),然后模拟对应位置数字相加的过程,最后将相加的结果转换为字符串结果。下面是具体的代码:

# 使用列表来存储两个加数的各个位置上的数字
def add(a: str, b: str):
    # AB存储两个加数对应位置上的数字, C用来存储相加之后的结果
    A, B, C = list(), list(), list()
    for i in range(len(a) - 1, -1, -1):
        A.append(int(a[i]))
    for i in range(len(b) - 1, -1, -1):
        B.append(int(b[i]))
    i = 0
    t = 0
    # 逆序遍历
    while i < len(A) or i < len(B) or t:
        if i < len(A): t += A[i]
        if i < len(B): t += B[i]
        C.append(t % 10)
        t //= 10
        i += 1
    z = ""
    for i in range(len(C) - 1, -1, -1):
        z += str(C[i])
    return z


if __name__ == '__main__':
    # 高精度加法主要是将字符串转换为数组或者列表相加
    print(add("12", "220"))

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值