LeetCode刷题实战43:字符串相乘
程序IT圈
共 3293字,需浏览 7分钟
·
2020-09-21 09:03
算法的重要性,我就不多说了吧,想去大厂,就必须要经过基础知识和业务逻辑面试+算法面试。所以,为了提高大家的算法能力,这个公众号后续每天带大家做一道算法题,题目就从LeetCode上面选 !
今天和大家聊的问题叫做 字符串相乘,我们先来看题面:
https://leetcode-cn.com/problems/multiply-strings/
Given two non-negative integers num1 and num2 represented as strings, return the product of num1 and num2, also represented as a string.
题意
样例
示例 1:
输入: num1 = "2", num2 = "3"
输出: "6"
示例 2:
输入: num1 = "123", num2 = "456"
输出: "56088"
num1 和 num2 的长度小于110。
num1 和 num2 只包含数字 0-9。
num1 和 num2 均不以零开头,除非是数字 0 本身。
不能使用任何标准库的大数类型(比如 BigInteger)或直接将输入转换为整数来处理。
解题
高精度与打竖式
123
* 224
____________
492
246
246
____________
27552
进位和前导零
class Solution:
def multiply(self, num1: str, num2: str) -> str:
# 将字符串转化成数组
# 翻转数组,因为我们用第0位表示个位
arr1 = [ord(i) - ord('0') for i in num1][:: -1]
arr2 = [ord(i) - ord('0') for i in num2][:: -1]
# 创建结果数组,可以证明结果的长度最多是n + m
n, m = len(arr1), len(arr2)
ret = [0for i in range(n + m + 1)]
for i in range(n):
for j in range(m):
# 按位相乘,计算进位
ret[i + j] += arr1[i] * arr2[j]
if ret[i+j] >= 10:
ret[i+j+1] += ret[i+j] // 10
ret[i+j] %= 10
# 最后把数组再转化成字符串返回
# 去除前导零
result = ''.join(map(str, ret))[::-1].lstrip('0')
return result if len(result) > 0else'0'
class Solution:
def multiply(self, num1: str, num2: str) -> str:
num1 = int(num1)
num2 = int(num2)
return str(num1 * num2)
上期推文:
评论