题目描述:
给定一个数组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]$$。不能使用除法。
解题思路:
时间复杂度: $O(n^2)$, 空间复杂度: $O(n)$.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
class Solution {
public:
vector<int> multiply(const vector<int>& A) {
vector<int> vec(A.size());
for(int j = 0; j <= A.size()-1; j++)
{
int temp = 1;
for(int i = 0; i <= A.size()-1; i++)
{
if(i != j)
temp = A[i] * temp;
}
vec[j] = temp;
}
return vec;
}
};
|
时间复杂度: $O(n)$, 空间复杂度: $O(n)$.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
class Solution {
public:
vector<int> multiply(const vector<int>& A) {
int n=A.size();
vector<int> b(n);
int ret=1;
for(int i=0;i<n;ret*=A[i++]){ //关键是for语句中的第三条语句,因为它是在循环体之后执行的。
b[i]=ret; //第二是两个for语句中循环体的不同。
}
ret=1;
for(int i=n-1;i>=0;ret*=A[i--]){
b[i]*=ret;
}
return b;
}
};
|