LeetCode 43. 字符串相乘C++代码 超过100%

简介: LeetCode 43. 字符串相乘C++代码 超过100%
43. 字符串相乘

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

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


示例 1:

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

输出: "6"


示例 2:

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

输出: "56088"

提示:

1 <= num1.length, num2.length <= 200

num1 和 num2 只能由数字组成。

num1 和 num2 都不包含任何前导零,除了数字0本身。

class Solution {
public:
    string multiply(string num1, string num2) {
        int n=num1.size();
        int m=num2.size();
        vector< int >arr(n+m,0);
        for(int i=n-1;i>=0;i--)
        {
            for(int j=m-1;j>=0;j--)
            {
                int num=(num1[i]-'0')*(num2[j]-'0');   //计算当前位置的乘积
                int sum=arr[i+j+1]+num;                //原来位置的数字加上当前位置数字 
                arr[i+j+1]=sum%10;                     //将数字赋给数组取余赋值
                arr[i+j]+=sum/10;                      //如果有进位 算数取整赋值给下一位
            }
        }
        bool que=true;                                  
        string ss;
        for(int i=0;i<arr.size();i++)
        {
            if(que==true&&arr[i]==0)                    //防止第一位是0的情况
            continue;
            que=false;
            ss+=to_string(arr[i]);                      //拼接数组
        }
        if(ss.empty())                                  //如果两数相乘结果为0 那么当前字符串为空 返回结果"0"
        return "0";        
        return ss;
    }
};

90ed6283226a431dbebdff639caf9a8c.png

目录
相关文章
|
2月前
|
算法 安全 C++
提高C/C++代码的可读性
提高C/C++代码的可读性
64 4
|
3月前
|
JavaScript
力扣3333.找到初始输入字符串Ⅱ
【10月更文挑战第9天】力扣3333.找到初始输入字符串Ⅱ
40 1
|
3月前
|
C++
Leetcode第43题(字符串相乘)
本篇介绍了一种用C++实现的字符串表示的非负整数相乘的方法,通过逆向编号字符串,将乘法运算转化为二维数组的累加过程,最后处理进位并转换为字符串结果,解决了两个大数相乘的问题。
30 9
|
3月前
|
Linux C语言 C++
vsCode远程执行c和c++代码并操控linux服务器完整教程
这篇文章提供了一个完整的教程,介绍如何在Visual Studio Code中配置和使用插件来远程执行C和C++代码,并操控Linux服务器,包括安装VSCode、安装插件、配置插件、配置编译工具、升级glibc和编写代码进行调试的步骤。
428 0
vsCode远程执行c和c++代码并操控linux服务器完整教程
|
3月前
|
算法 C++
Leetcode第八题(字符串转换整数(atoi))
这篇文章介绍了LeetCode上第8题“字符串转换整数(atoi)”的解题思路和C++的实现方法,包括处理前导空格、正负号、连续数字字符以及整数溢出的情况。
24 0
|
3月前
【LeetCode 22】459.重复的子字符串
【LeetCode 22】459.重复的子字符串
33 0
|
3月前
【LeetCode 20】151.反转字符串里的单词
【LeetCode 20】151.反转字符串里的单词
25 0
|
3月前
【LeetCode 19】541.反转字符串II
【LeetCode 19】541.反转字符串II
25 0
|
3月前
【LeetCode 18】6.2.反转字符串
【LeetCode 18】6.2.反转字符串
19 0
|
3月前
|
缓存 网络协议 API
C/C++ StringToAddress(字符串转 boost::asio::ip::address)
通过上述步骤和示例代码,你可以轻松地在C++项目中实现从字符串到 `boost::asio::ip::address`的转换,从而充分利用Boost.Asio库进行网络编程。
97 0