构建乘积数组

题目

给定一个数组A[0,1,…,n-1],请构建一个数组B[0,1,…,n-1],其中B中的元素B[i]=A[0]A[1]A[i-1]*A[i+1]…*A[n-1]。不能使用除法。

思路

借助中间变量存储后面的乘积

代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
function multiply(array) {
const B = [],
len = array.length;
B[0] = 1;
// 计算前i - 1个元素的乘积
for (let i = 1; i < len; i++) {
B[i] = array[i - 1] * B[i - 1];
}
let tmp = 1;
// 计算后N - i个元素的乘积并连接
for (let i = len - 2; i >= 0; i--) {
tmp *= array[i + 1];
B[i] *= tmp;
}
return B;
}