51.构建乘积数组
给定一个数组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]。不能使用除法。
通过观察B数组会发现,B[i]=A数组所有元素乘积/A[i]。但是题意说明不能使用除法。那么另外考虑:B[i]直观意义是B[i]项等于A数组所有数的乘积,但是去除A[i]项。由于是乘法,所以直接令A[i]项等于1即可。因此可以:
分为 i左边的元素乘积和 i右边的所有元素乘积。第一个for计算i左边的乘积,第二个for计算右边的。初始化B[0]=1,是因为0左边没有元素,所以乘积为1。
public class Solution {
public int[] multiply(int[] A) {
if(A==null|| A.length==0)
return null;
int len=A.length;
int[] B=new int[len];
B[0]=1;
// 计算前i-1个元素的乘积即计算下三角连乘
for(int i=1;i<len;i++){
B[i]=A[i-1]*B[i-1];
}
int temp=1;
// 计算后N-i个元素的乘积并连接---计算上三角乘积
for(int j=len-2;j>=0;j--){
temp*=A[j+1];
B[j]*=temp;
}
return B;
}
}
本文介绍了一种在不使用除法的情况下,构建一个数组B,其中B[i]等于另一个数组A中除了A[i]外所有元素的乘积的算法。通过两遍遍历和累积乘积的方法,有效地解决了问题。
190

被折叠的 条评论
为什么被折叠?



