10.Product of Array Except Self
Example
Input: [1,2,3,4]
Output: [24,12,8,6]Solution I : (Using Extra Space)
class Solution
{
public:
vector<int> productExceptSelf(vector<int> &nums)
{
int n = nums.size();
vector<int> v;
vector<int> pre(n);
vector<int> suf(n);
pre[0] = 1;
suf[n - 1] = 1;
for (int i = 1; i < nums.size(); i++)
{
pre[i] = pre[i - 1] * nums[i - 1];
}
for (int i = n - 2; i >= 0; i--)
{
suf[i] = suf[i + 1] * nums[i + 1];
}
for (int i = 0; i < n; i++)
{
v.push_back(suf[i] * pre[i]);
}
return v;
}
};Last updated