Leetcode 43. 字符串相乘

1.题目基本信息

1.1.题目描述

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

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

1.2.题目地址

https://leetcode.cn/problems/multiply-strings/description

2.解题方法

2.1.解题思路

数组+数字

2.2.解题步骤

第一步,临界值处理。当num1或者num2为0时,乘积为0,直接返回

第二步,m位数乘以n位数,最终结果不会超过m+n位数,所以将结果用一个m+n长度的数组arr进行存储。同时num1[i]*num2[j]可以认为是arr[i+j+1]的未进位时的值的组成部分。所以让乘数num1[i]*num2[j]的值加到arr[i+j+1]上

第三步,第二步获取的是未进位的arr数值数组,在这一步,从后往前遍历,将数组中各个位进行进位操作

第四步,将数组各个位进行连接,并删除前面的0项,即为最终数字的字符串

3.解题代码

Python代码

python 复制代码
class Solution:
    # 数组+数字
    def multiply(self, num1: str, num2: str) -> str:
        # 第一步,临界值处理。当num1或者num2为0时,乘积为0,直接返回
        if num1=="0" or num2=="0":
            return "0"
        # 第二步,m位数乘以n位数,最终结果不会超过m+n位数,所以将结果用一个m+n长度的数组arr进行存储。同时num1[i]*num2[j]可以认为是arr[i+j+1]的未进位时的值的组成部分。所以让乘数num1[i]*num2[j]的值加到arr[i+j+1]上
        length1,length2=len(num1),len(num2)
        arr=[0]*(length1+length2)
        for i in range(length1-1,-1,-1):
            x=int(num1[i])
            for j in range(length2-1,-1,-1):
                y=int(num2[j])
                arr[i+j+1]+=x*y
        # 第三步,第二步获取的是未进位的arr数值数组,在这一步,从后往前遍历,将数组中各个位进行进位操作
        extra=0
        for i in range(length1+length2-1,-1,-1):
            temp=(arr[i]+extra)%10
            extra=(arr[i]+extra)//10
            arr[i]=temp
        index=0 if arr[0]!=0 else 1
        # 第四步,将数组各个位进行连接,并删除前面的0项,即为最终数字的字符串
        result="".join([str(i) for i in arr[index:]])
        # print(result)
        return result

C++代码

cpp 复制代码
class Solution {
public:
    string multiply(string num1, string num2) {
        if(num1=="0" || num2=="0"){
            return "0";
        }
        int length1=num1.size(),length2=num2.size();
        vector<int> arr(length1+length2,0);
        for(int i=length1-1;i>=0;--i){
            int x=num1.at(i)-'0';
            for(int j=length2-1;j>=0;--j){
                int y=num2.at(j)-'0';
                arr[i+j+1]+=x*y;
            }
        }
        int extra=0;
        for(int i=length1+length2-1;i>=0;--i){
            int temp=arr[i]+extra;
            extra=temp/10;
            arr[i]=temp%10;
        }
        string result;
        int index=arr[0]==0 ? 1 : 0;
        while(index<length1+length2){
            cout << arr[index] << endl;
            result+=arr[index]+'0';
            index++;
        }
        return result;
    }
};

4.执行结果

相关推荐
海琴烟Sunshine2 小时前
leetcode 383. 赎金信 python
python·算法·leetcode
cynicme8 小时前
力扣3228——将 1 移动到末尾的最大操作次数
算法·leetcode
熬了夜的程序员8 小时前
【LeetCode】109. 有序链表转换二叉搜索树
数据结构·算法·leetcode·链表·职场和发展·深度优先
随意起个昵称8 小时前
【递归】二进制字符串中的第K位
c++·算法
mjhcsp9 小时前
C++ 循环结构:控制程序重复执行的核心机制
开发语言·c++·算法
立志成为大牛的小牛9 小时前
数据结构——四十一、分块查找(索引顺序查找)(王道408)
数据结构·学习·程序人生·考研·算法
xier_ran9 小时前
深度学习:RMSprop 优化算法详解
人工智能·深度学习·算法
地平线开发者9 小时前
不同传感器前中后融合方案简介
算法·自动驾驶
地平线开发者10 小时前
征程 6X 常见 kernel panic 问题
算法·自动驾驶
com_4sapi11 小时前
2025 权威认证头部矩阵系统全景对比发布 双榜单交叉验证
大数据·c语言·人工智能·算法·矩阵·机器人