日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python中字符串乘法_python leetcode 字符串相乘实例详解

發(fā)布時間:2023/12/2 python 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python中字符串乘法_python leetcode 字符串相乘实例详解 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

給定兩個以字符串形式表示的非負整數(shù) num1 和? num2 ,返回? num1 和? num2 的乘積,它們的乘積也表示為字符串形式。

示例 1:

輸入: num1 = "2", num2 = "3"

輸出: "6"

示例 2:

輸入: num1 = "123", num2 = "456"

輸出: "56088"

說明:

num1? 和? num2? 的長度小于110。

num1? 和? num2? 只包含數(shù)字? 0-9 。

num1? 和? num2? 均不以零開頭,除非是數(shù)字 0 本身。

不能使用任何標準庫的大數(shù)類型(比如 BigInteger)或直接將輸入轉換為整數(shù)來處理。

從題目要求來看,應該是讓我們實現(xiàn)一個比較省內存的大數(shù)乘法,先分享幾個我在discuss中發(fā)現(xiàn)的不太切合題意的解法:

class Solution:

def multiply(self, num1, num2):

"""

:type num1: str

:type num2: str

:rtype: str

"""

return str(eval(num1+'*'+num2))

這個可以說是個毫無技術含量的解法,如果面試的時候掏出這種解法,八成是跪了。

還有很多人使用了以下的解法。

class Solution:

def multiply(self, num1, num2):

"""

:type num1: str

:type num2: str

:rtype: str

"""

dict = {'0':0, '1':1, '2':2, '3':3, '4':4, '5':5, '6':6, '7':7, '8':8, '9':9}

if (num1=='0' or num2=='0'):

return "0"

n1 = 0

n2 = 0

for c in num1:

val = dict[c]

n1 = n1*10 + val

for s in num2:

val = dict[s]

n2 = n2*10 + val

result = n1 * n2;

return str(result)

這種解法我覺得還是沒有切合題意,將注意力放在的字符串轉數(shù)字上,乘法還是使用的*。題目要求不能將輸入直接轉成數(shù)字類型,解體人自己實現(xiàn)了int方法完成了字符串的轉換,好像是符合要求,但有投機取巧的感覺。

我來分享一下我的解法,思路很簡單也很好理解,當我們徒手計算222*11時我們怎么計算呢,肯定是分解成222+2220來計算的,那么我們就可以使用一個一維列表來記錄計算結果11分解成10+1,第一輪計算列表的結果為[0, 2, 2, 2],第二輪計算后變?yōu)閇2, 2+2, 2+2, 2]計算結束。如果需要進位的話,進位的計算放到最后一步。

class Solution(object):

def multiply(self, num1, num2):

"""

:type num1: str

:type num2: str

:rtype: str

"""

if num1 == "0" or num2 == "0":

return "0"

num1 = num1[::-1]

num2 = num2[::-1]

str_list = [0 for _ in range(len(num1)+len(num2))]

for i in range(len(num1)):

for j in range(len(num2)):

str_list[i+j] += (int(num1[i])*int(num2[j]))

result = ""

up = 0

for i in str_list:

now = i + up

cur = now % 10

up = now / 10

result += str(cur)

begin = 0

result = result[::-1]

for i in result:

if i == "0":

begin += 1

else:

break

return result[begin:]

本文標題: python leetcode 字符串相乘實例詳解

本文地址: http://www.cppcns.com/jiaoben/python/238863.html

總結

以上是生活随笔為你收集整理的python中字符串乘法_python leetcode 字符串相乘实例详解的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。