Leetcode 43. 字符串相乘

文章提供了三种不同的C++代码实现,解决LeetCode第43题——字符串相乘的问题。主要方法是通过反转输入字符串,然后逐位进行乘法运算,处理进位。代码中考虑了‘0’乘任何数等于‘0’的特殊情况,并在最后整理结果时移除前导零。
摘要由CSDN通过智能技术生成

题目

在这里插入图片描述
Leetcode 43. 字符串相乘


代码(5.2 首刷看解析)

在这里插入图片描述

class Solution {
public:
    string multiply(string num1, string num2) {
        if(num1 == "0" || num2 == "0")
            return "0";
        reverse(num1.begin(), num1.end());
        reverse(num2.begin(), num2.end());
      
        int m = num1.size(), n = num2.size();
        vector<int> tmp(m+n+1, 0);
        for(int i = 0; i < m; i++) {
            for(int j = 0; j < n; j++) {
                int n1 = num1[i]-'0';
                int n2 = num2[j]-'0';
                tmp[i+j] += n1*n2;
            }
        }
        string ans="";
        for(int i = 0; i < m+n; i++) {
            tmp[i+1] += tmp[i]/10;
            tmp[i] = tmp[i]%10;
            if(i == m+n-1 && tmp[i] == 0)   // 如果最高位没有进位,则则不需要把0包括进去
                continue;
            ans += tmp[i]+'0';
        }
        reverse(ans.begin(), ans.end());
        return ans;
    }
};

代码(7.5 二刷看解析)

若模拟真实乘法,会出现溢出的情况。

class Solution {
public:
    string multiply(string num1, string num2) {
        if(num1 == "0" || num2 == "0")
            return "0";
        reverse(num1.begin(), num1.end());
        reverse(num2.begin(), num2.end());
        int m = num1.size(), n = num2.size();
        vector<int> tmp(m+n+1);
        for(int i = 0; i < m; i++) {
            for(int j = 0; j < n; j++) {
                int a = num1[i]-'0', b = num2[j]-'0';
                tmp[i+j] += a*b;
            }
        }
        string res = "";
        for(int i = 0; i < m+n; i++) {
            tmp[i+1] += tmp[i]/10;
            tmp[i] %= 10;
            if(i == m+n-1 && tmp[i] == 0) // 如果最高位没有进位,则则不需要把0包括进去
                continue;
            res += tmp[i] + '0';
        }
        reverse(res.begin(), res.end());
        return res;
    }
};

代码(9.7 三刷自解)

class Solution {
public:
    string multiply(string num1, string num2) {
        if(num1 == "0" || num2 == "0")
            return "0";
        reverse(num1.begin(), num1.end());
        reverse(num2.begin(), num2.end());
        int m = num1.size(), n = num2.size();
        vector<int> nums(m+n+1);
        int flag = 0;
        for(int i = 0; i < m; i++) {
            for(int j = 0; j < n; j++) {
                int num = (num1[i]-'0')*(num2[j]-'0');
                nums[i+j] += num;
                // cout<<nums[i+j]<<" ";
            }
        }
        string ans;
        for(int i = 0; i < m+n; i++) {
            int num = nums[i];
            nums[i] %= 10;
            nums[i+1] += num/10;
            cout<<num<<" ";
            ans.push_back(nums[i]+'0');
        }
        reverse(ans.begin(), ans.end());
        int i = 0;
        while(ans[i] == '0') i++;
        return ans.substr(i);
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值