238 Product of Array Except Self

Given an array of n integers where n > 1, nums, return an array output such that output[i] is equal to the product of all the elements of nums except nums[i].

Solve it without division and in O(n).

For example, given [1,2,3,4], return [24,12,8,6].

Follow up: Could you solve it with constant space complexity? (Note: The output array does not count as extra space for the purpose of space complexity analysis.)

Show Company Tags Show Tags Show Similar Problems

分析

输入:至少含有2个元素的数组nums

输出:同size的数组,元素为其余乘积

要求:计算复杂度:O(n)-----》暗示数组只能遍历一遍

Corner Case:

1.全是0

思路1:Brute Force

复杂度:O(n^2)

如何才能降低计算复杂度?-------》trade space for speed

思路2:多建两个数组

pFromBegin[i] = nums[0]num[1]...*num[i]

pFromEnd[i] = num[n-1]...num[i+1]*num[i]

output[i] = pFromBegin[i-1] * pFromEnd[i+1]

思路2实现遇到的问题

1.求数组的起点

由于pFromBegin[i] = pFromBegin[i-1] * nums[i];因此当i==0时需要特殊处理。

同理,由于pFromEnd[i] = pFromEnd[i+1] * nums[i];因此当i==pFromEnd.length-1时需要特殊处理。

还同理,由于output[i] = pFromBegin[i-1] * pFromEnd[i+1];因此当i==0或i==lengthOfNums-1时需要特殊处理。

2.关于求pFromEnd[i],由于用到的是pFromEnd[i+1] ,因此for中的循环是递减

    for(int i=pFromEnd.length-1; i>= 0; i--)

思路2复杂度

1.算pFromBegin和pFromEnd-----》O(n)+O(n) 2.算output-----》O(n)

运算复杂度:O(n)

需要两个于输入数组尺寸相同的array,因此空间复杂度:O(n)

AC Code

public class Solution {
    public int[] productExceptSelf(int[] nums) {

    int lengthOfNums = nums.length;
    int[] output = new int[lengthOfNums];

    int[] pFromBegin = new int[lengthOfNums];
    int[] pFromEnd = new int[lengthOfNums];

    for(int i=0; i<pFromBegin.length; i++) {
        if(i==0) pFromBegin[i] = nums[i];
        else {
        pFromBegin[i] = pFromBegin[i-1] * nums[i];
        }
    }

    for(int i=pFromEnd.length-1; i>= 0; i--) {
        if(i==pFromEnd.length-1) pFromEnd[i] = nums[i];
        else {
        pFromEnd[i] = pFromEnd[i+1] * nums[i];
        }
    }

    for(int i=0; i<lengthOfNums; i++) {
        if(i==0) output[i] = pFromEnd[i+1];
        else if(i==lengthOfNums-1) output[i] = pFromBegin[i-1];
        else output[i] = pFromBegin[i-1] * pFromEnd[i+1];
    }

    return output;
    }
}

Follow Up:空间复杂度O(1)

其实不需要建立额外数组,可以直接在output中更新乘积

results matching ""

    No results matching ""