字符串乘法计算

LeetCode力扣难度
43. Multiply Strings43. 字符串相乘🟠

目录

题目

图片&文件

思路:模拟手算

图片&文件

    1 2 3
  ×   4 5
---------
      1 5     (3 × 5)
    1 0       (2 × 5)
  5           (1 × 5)
    1 2       (3 × 4)
  8           (2 × 4)
4             (1 × 4)
---------
5 5 3 5
  • 先计算 3×5=151 放在result[3]5 放在result[4]
  • 再计算 2x5 = 10
  • ….

num1[i] 和 num2[j] 的乘积对应的就是 res[i+j] 和 res[i+j+1],如下图

  • 3 * 412
    • res[2] = 1
    • res[3] = 2

图片&文件

代码

var multiply = function(num1, num2) {
    let m = num1.length, n = num2.length;
    // 结果最多为 m + n 位数
    let res = new Array(m + n).fill(0);
    // 从个位数开始逐位相乘
    for (let i = m - 1; i >= 0; i--) {
        for (let j = n - 1; j >= 0; j--) {
            let mul = (num1[i] - '0') * (num2[j] - '0');
            // 乘积在 res 对应的索引位置
            let p1 = i + j, p2 = i + j + 1;
            // 叠加到 res 上
            let sum = mul + res[p2];
            res[p2] = sum % 10;
            res[p1] += Math.floor(sum / 10);
        }
    }
    // 结果前缀可能存的 0(未使用的位)
    let i = 0;
    while (i < res.length && res[i] == 0)
        i++;
    // 将计算结果转化成字符串
    let str = "";
    for (; i < res.length; i++)
        str += res[i];
    
    return str.length == 0 ? "0" : str;
}