【剑斩OFFER】算法的暴力美学——力扣 43 题:字符串相乘

一、题目描述

二、算法原理

思路:无进位相乘

首先我们先把两个字符串进行逆序:

然后开辟一个数组,这个数组的大小为:两个字符串的长度 - 1,原因:假设是三位数乘以三位数,那么这个三位数的最大值位:999 * 999 :

那么决定开辟数组的长度的是从左往有看的第一个数:

那么:

所以:我们开辟的数组的大小是两个字符串的长度 - 1,那么怎么存储相乘之后的值呢?

例如: 3 * 5 的值放到 3 的下标为 0,5 的下标为:1 ,那么放到这个数组下标为: 0 + 1 = 1 里面:

如果再遇到放到数组下标为 1 里面,或者说这个数组下标里面已经有元素了,则加等上去,例如:2 * 6 = 12

最终这个数组的值为:

我可以用一个 string ret 来存储数组每个元素的余数,然后再翻转这个字符串就行,注意求数组的每个元素的余数是从下标为0开始求。

三、代码实现

cpp 复制代码
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 n1 = num1.size(),n2 = num2.size();
        vector<int> arr(n1 + n2 - 1,0);//存储无进位相乘的结果

        // 无进位相乘
        for(int i = 0; i < n1; i++)
        {
            for(int j = 0; j < n2; j++)
            {
                arr[i + j] += (num1[i] - '0') * (num2[j] - '0');
            }
        }

        //加法运算
        string ret;
        int t = 0;
        for(int i = 0; i < (n1 + n2 - 1); i++)
        {
            t += arr[i];
            ret += ((t % 10) + '0');
            t /= 10;
        }
        if(t)
            ret += ((t % 10) + '0');
        reverse(ret.begin(),ret.end());
        return ret;
    }
};
相关推荐
小O的算法实验室16 小时前
2026年ASOC,基于深度强化学习的无人机三维复杂环境分层自适应导航规划方法,深度解析+性能实测
算法·无人机·论文复现·智能算法·智能算法改进
‎ദ്ദിᵔ.˛.ᵔ₎17 小时前
LIST 的相关知识
数据结构·list
M--Y17 小时前
Redis常用数据类型
数据结构·数据库·redis
郭涤生18 小时前
STL vector 扩容机制与自定义内存分配器设计分析
c++·算法
༾冬瓜大侠༿18 小时前
vector
c语言·开发语言·数据结构·c++·算法
Ricky111zzz18 小时前
leetcode学python记录1
python·算法·leetcode·职场和发展
汀、人工智能18 小时前
[特殊字符] 第58课:两个正序数组的中位数
数据结构·算法·数据库架构··数据流·两个正序数组的中位数
liu****18 小时前
第16届省赛蓝桥杯大赛C/C++大学B组(京津冀)
开发语言·数据结构·c++·算法·蓝桥杯
汀、人工智能18 小时前
[特殊字符] 第79课:分割等和子集
数据结构·算法·数据库架构·位运算·哈希表·分割等和子集
汀、人工智能18 小时前
[特殊字符] 第74课:完全平方数
数据结构·算法·数据库架构·图论·bfs·完全平方数