[43][中等] 字符串相乘
题目描述
给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式。
示例 1:
输入: num1 = "2", num2 = "3"
输出: "6"
示例 2:
输入: num1 = "123", num2 = "456"
输出: "56088"
说明:
num1 和 num2 的长度小于110。
num1 和 num2 只包含数字 0-9。
num1 和 num2 均不以零开头,除非是数字 0 本身。
不能使用任何标准库的大数类型(比如 BigInteger)或直接将输入转换为整数来处理。
解题思路
竖式乘法, 内外双层循环跑不了, 简单的思路就是先不考虑进位, 将num1
的第个字符和num2
的第个字符计算, 都放在结果的第位上(竖式乘法的思路).
然后将所有的结果计算出来, 每位的结果都各自累加, 再最后对结果列表循环过一遍, 处理进位.
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])
最后更新于
这有帮助吗?