C++ | Leetcode C++题解之第43题字符串相乘

题目:

题解:

cpp 复制代码
class Solution {
public:
    string multiply(string num1, string num2) {
        if (num1 == "0" || num2 == "0") {
            return "0";
        }
        int m = num1.size(), n = num2.size();
        auto ansArr = vector<int>(m + n);
        for (int i = m - 1; i >= 0; i--) {
            int x = num1.at(i) - '0';
            for (int j = n - 1; j >= 0; j--) {
                int y = num2.at(j) - '0';
                ansArr[i + j + 1] += x * y;
            }
        }
        for (int i = m + n - 1; i > 0; i--) {
            ansArr[i - 1] += ansArr[i] / 10;
            ansArr[i] %= 10;
        }
        int index = ansArr[0] == 0 ? 1 : 0;
        string ans;
        while (index < m + n) {
            ans.push_back(ansArr[index]);
            index++;
        }
        for (auto &c: ans) {
            c += '0';
        }
        return ans;
    }
};
相关推荐
挖矿大亨3 分钟前
C++中左移运算符重载
开发语言·c++
CoderCodingNo5 分钟前
【GESP】C++五级真题(数论-素数、贪心思想考点) luogu-B4050 [GESP202409 五级] 挑战怪物
开发语言·c++·算法
~光~~12 分钟前
【记录——内核模块加载到内核】基于鲁班猫4 rk3588s
c++·学习·rk3588s
老王熬夜敲代码29 分钟前
C++模版元编程2
开发语言·c++
hope_wisdom39 分钟前
C/C++数据结构之队列基础
c语言·数据结构·c++·队列·queue
图形学爱好者_Wu39 分钟前
C++ 数据结构 | 数组的底层原理
c++
阿猿收手吧!1 小时前
【C++】brpc与grpc对比
开发语言·c++
oioihoii1 小时前
C++虚函数表与多重继承内存布局深度剖析
java·jvm·c++
BestOrNothing_20151 小时前
C++ 内存泄漏的“真实成本”: 内存单位换算、堆分配开销与工程级判断
c++·内存管理·内存泄漏·堆内存·raii·内存换算·异常安全
YGGP1 小时前
【Golang】LeetCode 72. 编辑距离
算法·leetcode