时间:2021-05-22
给定两个以字符串形式表示的非负整数 num1 和 num2 ,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式。
示例 1:
输入: num1 = "2", num2 = "3"
输出: "6"
示例 2:
输入: num1 = "123", num2 = "456"
输出: "56088"
说明:
不能使用任何标准库的大数类型(比如 BigInteger)或直接将输入转换为整数来处理。
从题目要求来看,应该是让我们实现一个比较省内存的大数乘法,先分享几个我在discuss中发现的不太切合题意的解法:
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)这种解法我觉得还是没有切合题意,将注意力放在的字符串转数字上,乘法还是使用的*。题目要求不能将输入直接转成数字类型,解体人自己实现了int方法完成了字符串的转换,好像是符合要求,但有投机取巧的感觉。
我来分享一下我的解法,思路很简单也很好理解,当我们徒手计算222*11时我们怎么计算呢,肯定是分解成222+2220来计算的,那么我们就可以使用一个一维列表来记录计算结果11分解成10+1,第一轮计算列表的结果为[0, 2, 2, 2],第二轮计算后变为[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:]声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
C++宽字符与普通字符的转换实例详解把字符串转换成宽字符串,实例代码:wstringstring2Wstring(stringsToMatch){#ifdef_
python里使用正则的findall函数的实例详解在前面学习了正则的search()函数,这个函数可以找到一个匹配的字符串返回,但是想找到所有匹配的字符串返回
本文实例讲述了python实现在字符串中查找子字符串的方法。分享给大家供大家参考。具体如下:这里实现python在字符串中查找子字符串,如果找到则返回子字符串的
C++中字符串操作--宽窄字符转换的实例详解MultiByteToWideCharintMultiByteToWideChar(_In_UINTCodePage
Python字符串(string)详解及代码Python的字符串可以使用单引号('),双引号("),三引号(''');三引号(''')里面,可以添加单引号和双引