字符串乘法计算
| LeetCode | 力扣 | 难度 |
|---|---|---|
| 43. Multiply Strings | 43. 字符串相乘 | 🟠 |
目录
题目

思路:模拟手算

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=15,1放在result[3],5放在result[4] - 再计算
2x5 = 10 - ….
num1[i] 和 num2[j] 的乘积对应的就是 res[i+j] 和 res[i+j+1],如下图
3 * 4等12res[2] = 1res[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;
}