43. Multiply Strings
Description
Given two non-negative integers num1
and num2
represented as strings, return the product of num1
and num2
, also represented as a string.
Note: You must not use any built-in BigInteger library or convert the inputs to integer directly.
Example 1:
Input: num1 = "2", num2 = "3" Output: "6"
Example 2:
Input: num1 = "123", num2 = "456" Output: "56088"
Constraints:
1 <= num1.length, num2.length <= 200
num1
andnum2
consist of digits only.- Both
num1
andnum2
do not contain any leading zero, except the number0
itself.
Solution
multiply-strings.py
class Solution:
def multiply(self, num1: str, num2: str) -> str:
m, n = len(num1), len(num2)
A = [0] * (m + n)
for i in range(m - 1, -1, -1):
for j in range(n - 1, -1, -1):
mul = (ord(num1[i]) - ord('0')) * (ord(num2[j]) - ord('0'))
p1, p2 = i + j, i + j + 1
ssum = mul + A[p2]
A[p1] += ssum // 10
A[p2] = ssum % 10
res = ""
for c in A:
if res or c != 0:
res += str(c)
return res or "0"