[LeetCode] 238. Product of Array Except Self 除本身之外的数组之积
Given an array nums of n integers where n > 1,  return an array output such that output[i] is equal to the product of all the elements of numsexcept nums[i].
Example:
Input:[1,2,3,4]
Output:[24,12,8,6]
Note: Please solve it without division and in O(n).
Follow up:
Could you solve it with constant space complexity? (The output array does not count as extra space for the purpose of space complexity analysis.)
这道题给定我们一个数组,让我们返回一个新数组,对于每一个位置上的数是其他位置上数的乘积,并且限定了时间复杂度 O(n),并且不让我们用除法。如果让用除法的话,那这道题就应该属于 Easy,因为可以先遍历一遍数组求出所有数字之积,然后除以对应位置的上的数字。但是这道题禁止我们使用除法,那么我们只能另辟蹊径。我们想,对于某一个数字,如果我们知道其前面所有数字的乘积,同时也知道后面所有的数乘积,那么二者相乘就是我们要的结果,所以我们只要分别创建出这两个数组即可,分别从数组的两个方向遍历就可以分别创建出乘积累积数组。参见代码如下:
C++ 解法一:
class Solution {
public:
    vector<int> productExceptSelf(vector<int>& nums) {
        int n = nums.size();
        vector<int> fwd(n, ), bwd(n, ), res(n);
        for (int i = ; i < n - ; ++i) {
            fwd[i + ] = fwd[i] * nums[i];
        }
        for (int i = n - ; i > ; --i) {
            bwd[i - ] = bwd[i] * nums[i];
        }
        for (int i = ; i < n; ++i) {
            res[i] = fwd[i] * bwd[i];
        }
        return res;
    }
};
Java 解法一:
public class Solution {
    public int[] productExceptSelf(int[] nums) {
        int n = nums.length;
        int[] res = new int[n];
        int[] fwd = new int[n], bwd = new int[n];
        fwd[0] = 1; bwd[n - 1] = 1;
        for (int i = 1; i < n; ++i) {
            fwd[i] = fwd[i - 1] * nums[i - 1];
        }
        for (int i = n - 2; i >= 0; --i) {
            bwd[i] = bwd[i + 1] * nums[i + 1];
        }
        for (int i = 0; i < n; ++i) {
            res[i] = fwd[i] * bwd[i];
        }
        return res;
    }
}
我们可以对上面的方法进行空间上的优化,由于最终的结果都是要乘到结果 res 中,所以可以不用单独的数组来保存乘积,而是直接累积到结果 res 中,我们先从前面遍历一遍,将乘积的累积存入结果 res 中,然后从后面开始遍历,用到一个临时变量 right,初始化为1,然后每次不断累积,最终得到正确结果,参见代码如下:
C++ 解法二:
class Solution {
public:
    vector<int> productExceptSelf(vector<int>& nums) {
        vector<int> res(nums.size(), );
        for (int i = ; i < nums.size(); ++i) {
            res[i] = res[i - ] * nums[i - ];
        }
        int right = ;
        for (int i = nums.size() - ; i >= ; --i) {
            res[i] *= right;
            right *= nums[i];
        }
        return res;
    }
};
Java 解法二:
public class Solution {
    public int[] productExceptSelf(int[] nums) {
        int n = nums.length, right = 1;
        int[] res = new int[n];
        res[0] = 1;
        for (int i = 1; i < n; ++i) {
            res[i] = res[i - 1] * nums[i - 1];
        }
        for (int i = n - 1; i >= 0; --i) {
            res[i] *= right;
            right *= nums[i];
        }
        return res;
    }
}
Github 同步地址:
https://github.com/grandyang/leetcode/issues/238
类似题目:
参考资料:
https://leetcode.com/problems/product-of-array-except-self/
https://leetcode.com/problems/product-of-array-except-self/discuss/65638/My-simple-Java-solution
LeetCode All in One 题目讲解汇总(持续更新中...)
[LeetCode] 238. Product of Array Except Self 除本身之外的数组之积的更多相关文章
- [LintCode] Product of Array Except Self 除本身之外的数组之积
		Given an integers array A. Define B[i] = A[0] * ... * A[i-1] * A[i+1] * ... * A[n-1], calculate B WI ... 
- LeetCode 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 equ ... 
- [LeetCode] Product of Array Except Self 除本身之外的数组之积
		Given an array of n integers where n > 1, nums, return an array output such that output[i] is equ ... 
- [leetcode]238. Product of Array Except Self除了自身以外的数组元素乘积
		Given an array nums of n integers where n > 1, return an array output such that output[i] is equ ... 
- LN : leetcode 238 Product of Array Except Self
		lc 238 Product of Array Except Self 238 Product of Array Except Self Given an array of n integers wh ... 
- Java [Leetcode 238]Product of Array Except Self
		题目描述: Given an array of n integers where n > 1, nums, return an array output such that output[i] ... 
- 剑指offer 66. 构建乘积数组(Leetcode 238. Product of Array Except Self)
		剑指offer 66. 构建乘积数组 题目: 给定一个数组A[0, 1, ..., n-1],请构建一个数组B[0, 1, ..., n-1],其中B中的元素B[i] = A[0] * A[1] * ... 
- (medium)LeetCode  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 equ ... 
- C#解leetcode   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 equ ... 
随机推荐
- 使用 Hbuilder 连接手机调试移动端项目
			点击界面上的浏览器右侧的倒三角. 弹出列表以后,点击最后一行 “设置web服务器...”.继续弹出,点击右下角的“外置Web服务器设置”. 点新建. 弹出框后,填入“名称”和“浏览器运行U ... 
- 【Sublime】Sublime 常用插件
			1.sublime设置默认浏览器及打开网页的快捷键设置插件 名称:SideBarEnhancements 地址:https://github.com/titoBouzout/SideBarEnhanc ... 
- Linux系统管理图文详解超详细精心整理
			前言:带你遨游于linux系统管理知识的海洋,沐浴春日里的阳光,循序渐进,看完之后收获满满. 本次讲解基于linux(centos6.5)虚拟机做的测试,centos7估计以后有时间再更新啊. lin ... 
- MongoDB创建集合和删除集合05-14学习笔记
			MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言编写,是一个基于分布式文件存储的开源数据库系统.旨在为 WEB 应用提供可扩展的高性能数据存储解决方案. MongoDB 是一个介于关 ... 
- GNSS频率分配表
			说明: 公开资料表示,GPS L3用于核爆炸等高能红外辐射事件的侦查,L4用于电离层研究. GLONASS FDMA信号G1.G2.G3三个频段各自频点见以下附表,摘自ITU的频率协调结果. GLON ... 
- Java 类加载机制(阿里)-何时初始化类
			(1)阿里的面试官问了两个问题,可以不可以自己写个String类 答案:不可以,因为 根据类加载的双亲委派机制,会去加载父类,父类发现冲突了String就不再加载了; (2)能否在加载类的时候,对类的 ... 
- LinqMethod 实现 LeftJoin
			LinqMethod 实现 LeftJoin Intro 有时候我们想实现 leftJoin 但是 Linq 提供的 Join 相当于是 INNER JOIN,于是就打算实现一个 LeftJoin 的 ... 
- 网上售卖几百一月的微信机器,Python几十行代码就能搞定
			前言 文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 作者: 故事胶片 PS:如有需要Python学习资料的小伙伴可以加点击下方链 ... 
- Linux网络——配置防火墙的相关命令
			Linux网络——配置防火墙的相关命令 摘要:本文主要学习了如何在Linux系统中配置防火墙. iptables命令 iptables准确来讲并不是防火墙,真正的防火墙是运行于系统内核中的netfil ... 
- JavaScript的七种数据类型
			我知道这个话题网上说法非常多,甚至还有分出什么"Array,Function"之类的阿猫阿狗的类型.今天来整理这个话题的时候,先贴一张MDN官方的说法: 这个分法是对的,也是目前来 ... 
