給定兩個以字串形式表示的非負整數 num1 和 num2,返回 num1 和 num2 的乘積,它們的乘積也表示為字串形式。
示例 1:
輸入: num1 = 「2」, num2 = 「3」示例 2:輸出: 「6」
輸入: num1 = 「123」, num2 = 「456」說明:輸出: 「56088」
num1 和 num2 的長度小於110。
num1 和 num2 只包含數字 0-9。
num1 和 num2 均不以零開頭,除非是數字 0 本身。
不能使用任何標準庫的大數型別(比如 biginteger)或直接將輸入轉換為整數來處理。
class
solution
(object):
defmultiply
(self, num1, num2)
:"""
:type num1: str
:type num2: str
:rtype: str
"""num1_len =
len(num1)
num2_len =
len(num2)
tmp1 =
tmp2 =
for index, i in
enumerate
(num1)
:int
(i)*
10**
(num1_len-index-1)
)for index, i in
enumerate
(num2)
:int
(i)*
10**
(num2_len-index-1)
)def
func
(a,b)
:return a+b
from functools import
reduce
num1 =
reduce
(func, tmp1)
num2 =
reduce
(func, tmp2)
return
str(num1*num2)
43 字串相乘
給定兩個以字串形式表示的非負整數 num1 和 num2,返回 num1 和 num2 的乘積,它們的乘積也表示為字串形式。示例 1 輸入 num1 2 num2 3 輸出 6 示例 2 輸入 num1 123 num2 456 輸出 56088 說明 num1 和 num2 的長度小於110。nu...
43 字串相乘
題目描述 給定兩個以字串形式表示的非負整數 num1 和 num2,返回 num1 和 num2 的乘積,它們的乘積也表示為字串形式。示例 1 輸入 num1 2 num2 3 輸出 6 示例 2 輸入 num1 123 num2 456 輸出 56088 說明 num1 和 num2 的長度小於1...
43 字串相乘
小聲bb,直接int 多好 既然題目要求不能直接用int 我只好開動我的大腦開始想有什麼解決方案。然後首先想到的就是小學時候老師教乘法時用乘式寫法。1 2 3 4 5 6 1 5 4 9 2 5 5 3 51 2 3 4 5 1 51 0 0 5 0 6 1 5 1 20 8 0 4 0 5 5 3...