python 大数相加,大数相加 - zh的个人空间 - OSCHINA - 中文开源技术交流社区

思路:将两个大数分类按位放进两个数组中,以最长的字符串为准不足的补 0 ,然后按位相加,之后反序遍历结果数组,如果需要进位,则当前位数据对 10 求余数,然后向前进一位  。

代码实现如下:

def big_num_add():

s1 = raw_input("please enter a number:")

s2 = raw_input("please enter another number:")

s1_arr = []

s2_arr = []

# 数组对齐空位补0

if len(s1) > len(s2):

for i in range(0, len(s1)-len(s2)):

s2_arr.append(0)

if len(s2) > len(s1):

for i in range(0, len(s2)-len(s1)):

s1_arr.append(0)

for i, j in zip(s1, s2):

s1_arr.append(int(i))

s2_arr.append(int(j))

# 按位相加

for index, _ in enumerate(s1_arr):

s1_arr[index] = s1_arr[index]+s2_arr[index]

s1_arr.reverse()

for index, value in enumerate(s1_arr):

if value >= 10:

if ((index+1) < len(s1_arr)):

s1_arr[index+1] += 1

s1_arr[index] = value % 10

s1_arr.reverse()

result_str = ""

for i in s1_arr:

result_str += str(i)

print result_str

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值