题目描述
给定一个数组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]。不能使用除法。
分析
设结果数组为res,给定数组为arr=[a,b,c,d],首先取:
- res[0] = 1
- res[1] = res[0]*arr[0] = a
- res[2] = res[1]*arr[1] = ab
- res[3] = res[2]*arr[2] = abc
再取temp = arr[4] = d
- res[2] = res[2]temp = abd,temp = temparr[2] = cd
- res[1] = res[1]temp = acd,temp = temparr[1] = bcd
- res[0] = res[0]temp = bcd,temp = temparr[0] = abcd
至此,res数组正确构造完毕。
代码实现
function multiply(arr)
{
var res = [], index = 1;
res[0] = 1;
for(var i = 0;i < arr.length-1;i++) {
res[index] = res[index-1] * arr[i];
index++;
}
var temp = arr[arr.length-1], index = res.length-2;
for(var i = arr.length-2;i >= 0;i--) {
res[i] *= temp;
temp *= arr[index--];
}
return res;
}
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。