题目要求:
给定两个字符串形式的非负整数 num1 和num2 ,计算它们的和。
注意:
num1 和num2 的长度都小于 5100.
num1 和num2 都只包含数字 0-9.
num1 和num2 都不包含任何前导零。
你不能使用任何內建 BigInteger 库, 也不能直接将输入的字符串转换为整数形式。
有三种方法:
第一种也是最笨的方法:
把字符串中每一个字符转换为ASCII码,减去’0’的ASCII码,就可以得到int型的数值,耗时间最长。
num1='99999'
num2='999'
a=0
for i in range(1,len(num2)+1):
a=a+(ord(num2[-i])-ord('0'))*(pow(10,(i-1)))
for i in range(1,len(num1)+1):
a=a+(ord(num1[-i])-ord('0'))*pow(10,(i-1))
print(a)
第二种:
先将字符串装换为列表,在进行操作。
num1_list=list(num1)
sum1=sum2=0
for i in num1_list:
sum1=sum1*10+int(i)
for i in num2_list:
sum2=sum2*10+int(i)
print(str(sum1+sum2))
第三种:
使用eval函数
print(str(eval(num1)+eval(num2)))