[43][中等] 字符串相乘
最后更新于
最后更新于
class Solution:
def multiply(self, num1: str, num2: str) -> str:
n, m = len(num1), len(num2)
if (n == 1 and num1 == '0') or (m == 1 and num2 == '0'):
return '0'
tmp_result = [0] * (n + m)
num1, num2 = num1[::-1], num2[::-1]
for i in range(n):
t1 = int(num1[i])
for j in range(m):
t2 = int(num2[j])
tmp_result[i + j] += t1 * t2
carry = 0
for i, t in enumerate(tmp_result):
t += carry
carry, real = t // 10, t % 10
tmp_result[i] = str(real)
if carry > 0:
tmp_result.append(str(carry))
tmp_result = tmp_result[:-1] if tmp_result[-1] == '0' else tmp_result
return ''.join(tmp_result[::-1])