字符串相乘——int数组转字符串

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

**注意:**不能使用任何内置的 BigInteger 库或直接将输入转换为整数。

示例 1:

复制代码
输入: num1 = "2", num2 = "3"
输出: "6"

示例 2:

复制代码
输入: num1 = "123", num2 = "456"
输出: "56088"

int数组转字符串

join只能用于 str类型的 数组

1. map

复制代码
"".join(map(str, arr))

2. 列表推导

复制代码
"".join([str(x) for x in arr])

思路

①其中一个数为0,这种情况必须单独处理。

②m*n 的最大位数 是 len(m+n),最小位数是(m+n-1),由9*9 ,1*1 可大致推断。

③multiplyRes[i+j+1] += n1* int(num2[j]) ,为什么是 i+j+1?

答:因为 m-1(个位)和 n-1(个位) 的乘积 放在数组的最后一个位置(m+n-1),正好是i+j+1

详细思路请看:https://www.bilibili.com/video/BV1ba4y1J7yh/?spm_id_from=333.1391.0.0&vd_source=eca9560dd11076f193a7713d6a13a4a3

算完之后再统一进位。

因为可能第一位是0,所以需单独处理一下,决定开始的idx是第一位还是第二位。

python 复制代码
class Solution:
    def multiply(self, num1: str, num2: str) -> str:
        if num1 == '0' or num2 == '0':
            return '0'
        m,n=len(num1),len(num2)
        multiplyRes=[0]*(m+n)
        for i in range(m):
            n1=int(num1[i])
            for j in range(n):
                multiplyRes[i+j+1] += n1* int(num2[j])


        for i in range(m+n-1,0,-1):
            multiplyRes[i-1]+=multiplyRes[i]//10
            multiplyRes[i]=multiplyRes[i]%10

        idx=0
        if multiplyRes[0]==0:
            idx=1
        return "".join(map(str, multiplyRes[idx:]))
相关推荐
渣渣苏1 小时前
硬核拆解 HNSW:亿级向量如何实现毫秒级召回?(上篇)
人工智能·算法·支持向量机·ai·向量数据库·hnsw·智能体
Pkmer1 小时前
古法编程·新解:Python 类型注解的"一箭三雕"之术
python·ai编程
吃好睡好便好1 小时前
在Matlab中绘制三维等高线图
开发语言·python·学习·算法·matlab·信息可视化
天若有情6731 小时前
自制C++万能字符串流式库 formort.h|对标标准库endl,零拷贝链式拼接神器
开发语言·c++
项目申报小狂人1 小时前
一种使用双向长短时记忆网络结合鲸鱼优化算法的类火星矿物元素精确定量分析模型
人工智能·算法·lstm
keineahnung23451 小时前
PyTorch symbolic_shapes 模組的 is_contiguous 從哪來?── sizes_strides_user 安裝與實作解析
人工智能·pytorch·python·深度学习
wangjialelele1 小时前
【SystemV】基于建造者模式的信号量
linux·c语言·c++·算法·建造者模式
njsgcs1 小时前
制作solidworks插件 装配体导出展开耗时分析
开发语言·c#·solidworks
C137的本贾尼1 小时前
别怕异步:`async` 和 `await` 的简单理解
开发语言·python