算法与数据结构(字符串相乘)

题目

思路

这道题我们可以使用竖式乘法,从右往左遍历每个乘数,将其相乘,并且把乘完的数记录在nums数组中,然后再进行进位运算,将同一列的数进行相加,进位。

解题过程

首先求出两个数组的长度,方便以后遍历。

判断若两个数组中有一个是0,则直接返回0。

然后定义last方便存储相乘后的数。

将num1与num2中的每一个数相乘,用nums记录相乘后得到的数。

接着进行进位运算,用flag记录进位的数。

从右往左遍历nums数组中的数。

这个函数是在0的位置插入一个元素,值为后面的,相当于不断地向前插入。

通过不断改变flag的值来实现向前进位。

最后判断,若最后一位仍有进位,则前插一个flag。

返回last字符串。

下面写了一个123*456的例子方便理解。

代码

cpp 复制代码
class Solution {
public:
    string multiply(string num1, string num2) {
        int len1=num1.length();
        int len2=num2.length();
        if(num1=="0" || num2 =="0")
            return "0";
        string last="";
        vector<int> nums(len1+len2);
        //用一个数组记录下来它们相乘得到的值
        for(int i=0;i<len1;i++)
        {
            for(int j=0;j<len2;j++)
            {
                nums[i+j] += (num1[i]-'0')*(num2[j]-'0');
            }
        }
        //做进位运算
        int flag = 0;
        for(int i=len1+len2-2;i>=0;i--)
        {
            last.insert(0, 1, (nums[i]+flag)%10 + '0');
            flag = (nums[i]+flag)/10;
        }
        if(flag!=0)
        last.insert(0, 1, flag + '0');
        return last;
    }
};
相关推荐
mit6.82416 分钟前
前后缀分解
算法
独自破碎E1 小时前
判断链表是否为回文
数据结构·链表
你好,我叫C小白1 小时前
C语言 循环结构(1)
c语言·开发语言·算法·while·do...while
寂静山林3 小时前
UVa 10228 A Star not a Tree?
算法
Neverfadeaway3 小时前
【C语言】深入理解函数指针数组应用(4)
c语言·开发语言·算法·回调函数·转移表·c语言实现计算器
Madison-No74 小时前
【C++】探秘vector的底层实现
java·c++·算法
Swift社区4 小时前
LeetCode 401 - 二进制手表
算法·leetcode·ssh
派大星爱吃猫4 小时前
顺序表算法题(LeetCode)
算法·leetcode·职场和发展
liu****5 小时前
8.list的模拟实现
linux·数据结构·c++·算法·list
地平线开发者5 小时前
征程 6 | 征程 6 工具链如何支持 Matmul/Conv 双 int16 输入量化?
算法·自动驾驶