返回顶部
首页 > 资讯 > 后端开发 > Python >python leetcode 字符串相
  • 362
分享到

python leetcode 字符串相

字符串pythonleetcode 2023-01-30 22:01:41 362人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式。 示例 1: 输入: num1 = "2", num2 = "3" 输出: "6" 示例 2: 输入: num

给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式。

示例 1:

输入: num1 = "2", num2 = "3"
输出: "6"

示例 2:

输入: num1 = "123", num2 = "456"
输出: "56088"

说明:

  1. num1 和 num2 的长度小于110。
  2. num1 和 num2 只包含数字 0-9
  3. num1 和 num2 均不以零开头,除非是数字 0 本身。
  4. 不能使用任何标准库的大数类型(比如 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:]

祝大家每天开心~

 

 

 

 

 

--结束END--

本文标题: python leetcode 字符串相

本文链接: https://lsjlt.com/news/179407.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • python leetcode 字符串相
    给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,它们的乘积也表示为字符串形式。 示例 1: 输入: num1 = "2", num2 = "3" 输出: "6" 示例 2: 输入: num...
    99+
    2023-01-30
    字符串 python leetcode
  • Python Leetcode 字符串中
    利用到了python中字典的collections.Counter()函数 collections中函数Counter的使用和用法:   counter工具用于支持便捷和快速地计数,   from collections import C...
    99+
    2023-01-30
    字符串 Python Leetcode
  • C++实现LeetCode(43.字符串相乘)
    [LeetCode] 43. Multiply Strings 字符串相乘 Given two non-negative integers num1 and...
    99+
    2024-04-02
  • C++实现LeetCode(97.交织相错的字符串)
    [LeetCode] 97.Interleaving String 交织相错的字符串 Given s1, s2, s3, find whether...
    99+
    2024-04-02
  • JavaC++leetcode执行一次字符串交换能否使两个字符串相等
    目录题目要求思路:模拟JavaC++Rust题目要求 思路:模拟 Java class Solution { public boolean areAlmostEqual...
    99+
    2022-11-13
    Java C++ 字符串交换相等 Java C++
  • Python中的字符串相似度
    目录Python字符串相似度Python相似度评估1. 在计算图片的相似度时,我自己用到过余弦距离2.欧式距离3. 曼哈顿距离4.切比雪夫距离5.闵可夫斯基距离6.标准化欧氏距离7....
    99+
    2024-04-02
  • 详解python字符串相关str
    目录1:访str单个字符2: 字符串连接3:str切片4:使用in 和not in 测试字符串5:str方法6:重复操作符7:分割字符串总结1:访str单个字符 #for循环迭代 n...
    99+
    2024-04-02
  • Python字符串比较:如何判断两个字符串是否相等?
    Python字符串比较:如何判断两个字符串是否相等? 在Python编程中,字符串是最常用的数据类型之一。当我们需要比较两个字符串时,通常需要判断它们是否相等。这篇文章将详细介绍Python中比较两个字符串的方法。 使用“==”运算符比较...
    99+
    2023-08-22
    python 开发语言 java Python
  • 如何分析python字符串相关str
    今天给大家介绍一下如何分析python字符串相关str。文章的内容小编觉得不错,现在给大家分享一下,觉得有需要的朋友可以了解一下,希望对大家有所帮助,下面跟着小编的思路一起来阅读吧。1:访str单个字符#for循环迭代name =...
    99+
    2023-06-26
  • JavaScript字符串运算符、字符串和数字相加的方法
    本篇内容介绍了“JavaScript字符串运算符、字符串和数字相加的方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能...
    99+
    2024-04-02
  • Python中怎么实现字符和字符串相关操作
    这篇文章给大家介绍Python中怎么实现字符和字符串相关操作,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Python字符(数位,字母和符号,比如$\@,%和*)是python程序的基本构件。每个程序都由字符构成。这些...
    99+
    2023-06-17
  • 如何理解Python中LeetCode的亲密字符串
    这篇文章将为大家详细讲解有关如何理解Python中LeetCode的亲密字符串,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。Title: 给定两个由小写字母构成的字符串A和B,只要...
    99+
    2023-06-02
  • python字典和json字符串如何相互转化
    这篇文章主要介绍了python字典和json字符串如何相互转化,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。python字典和json字符串...
    99+
    2024-04-02
  • Python——— 字符串
    (一)字符串     字符串是 Python 中最常用的数据类型。我们可以使用引号 ( ' 或 " ) 来创建字符串。顾名思义,羊肉串是由羊肉做成的串,而字符串就是由字符组成的。   字符串的本质是:字符序列。 2     Pyth...
    99+
    2023-09-02
    python 开发语言
  • python字符串
    字符串的操作方法很多,这里只选几种常用的(1)    字符串大小写转换1.    S.lower()    字母大写转换...
    99+
    2023-01-30
    字符串 python
  • python---字符串
    特性:不可修改 test = "my name is fengxiaoli" ###确定字符串中字符位置 print(test.rfind("m"))                  #找到m所在的位置,以最右边的为准 print(te...
    99+
    2023-01-31
    字符串 python
  • Python 字符串
        1.字符串的索引       2.字符串的切片   s[1:3]   从第二个数切片到第三个,上边界不包含在内。     s[3: ]     s[ :3]   没个给切片的边界,上边界默认是0,下边界默认是末尾。’     s[ ...
    99+
    2023-01-31
    字符串 Python
  • python 字符串
    字符串>>> a = 'Hello World!'>>> print (a)                # 输出完整字符串Hello World!>>> print (a[0])  ...
    99+
    2023-01-31
    字符串 python
  • Python中的字符串相关操作说明
    本篇内容介绍了“Python中的字符串相关操作说明”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!(1)切片操作:str1="hel...
    99+
    2023-06-02
  • PYTHON时间与字符串的互相转换
    这篇文章主要讲解了“PYTHON时间与字符串的互相转换”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PYTHON时间与字符串的互相转换”吧!1、字符串转换成时间[in]from d...
    99+
    2023-06-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作