码迷,mamicode.com
首页 > 其他好文 > 详细

238. Product of Array Except Self

时间:2017-05-17 10:17:25      阅读:155      评论:0      收藏:0      [点我收藏+]

标签:elf   ant   back   without   pts   nts   ota   form   equal   

Problem statement:

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.)

Solution one:

We can not do one traverse to get the total product of this array and traverse to get the product except for the element itself. If one element is 0 in this array, we can not get it return value.

We should analyze this problem the product except for the element itself is comprised of the element in front and at the back of it. The best solution does two directions traverse to find the product from left to it and the product form end to it.

The time complexity is O(n).

class Solution {
public:
    vector<int> productExceptSelf(vector<int>& nums) {
        if(nums.empty()){
            return {};
        }
        int frombegin = 1;
        int fromlast = 1;
        int size = nums.size(); 
        vector<int> product(size, 1);
        
        for(int i = 0; i < size; i++){
            product[i] *= frombegin;
            frombegin *= nums[i];
            product[size - 1 - i] *= fromlast;
            fromlast *= nums[size - 1 - i];
        }
        return product;
    }
};

238. Product of Array Except Self

标签:elf   ant   back   without   pts   nts   ota   form   equal   

原文地址:http://www.cnblogs.com/wdw828/p/6865620.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!