給定兩個非負整數的字串 num1
和 num2
,分別表示兩個數字。要求模擬乘法運算,並返回結果字串,不能使用內建的大數處理函式(例如 Python 的 int
或 BigInteger
)。
範例 1:
輸入: num1 = "2", num2 = "3"
輸出: "6"
範例 2:
輸入: num1 = "123", num2 = "456"
輸出: "56088"
限制條件:
1 <= num1.length, num2.length <= 200
num1
和 num2
只包含數字,且不包含前導零。num1
長度為 n1,num2
長度為 n2,那麼結果最大長度為 n1+n2。result
來存放每一位的計算結果。num1
和 num2
的每個位數,模擬逐位相乘的過程,並將計算結果累加到 result
對應的位置。num1.length + num2.length
的陣列 result
,用來存放中間結果。num1
和 num2
的每個位數,計算其乘積並加到對應位置。class Solution:
def multiply(self, num1: str, num2: str) -> str:
if num1 == "0" or num2 == "0":
return "0"
# 初始化結果數組,長度最多為 num1.length + num2.length
n1, n2 = len(num1), len(num2)
result = [0] * (n1 + n2)
# 倒序遍歷 num1 和 num2
for i in range(n1 - 1, -1, -1):
for j in range(n2 - 1, -1, -1):
# 計算對應位的乘積
mul = int(num1[i]) * int(num2[j])
# 確定累加的位置
pos1, pos2 = i + j, i + j + 1
# 加入到 result 對應位置
sum_ = mul + result[pos2]
result[pos2] = sum_ % 10 # 取餘數存當前位
result[pos1] += sum_ // 10 # 進位
# 去掉前導零,轉為字串
result_str = ''.join(map(str, result)).lstrip('0')
return result_str
num1
和 num2
的長度。希望這篇文章幫助你深入理解這道題目的解法!