Product of Array Except Self
2015-07-25 16:39
190 查看
Given an array of n integers where n > 1,
return an array
equal to the product of all the elements of
Solve it without division and in O(n).
For example, given
给定一个数组,求其第i位上除了nums[i]之外其他所有元素的乘积,组成的新的数组。
nums,
return an array
outputsuch that
output[i]is
equal to the product of all the elements of
numsexcept
nums[i].
Solve it without division and in O(n).
For example, given
[1,2,3,4], return
[24,12,8,6].
题目分析:
给定一个数组,求其第i位上除了nums[i]之外其他所有元素的乘积,组成的新的数组。解题方法一:
将原数组除0之外的所有元素相乘为total,并同时累加为0的元素,如果0的元素大于等于0,则新数组全部为0,如果只有一个元素为0,则记录此值得位置,这个位置上的新数组元素为total,除此之外均为0.如果没有0存在,则用total除以原位置上的值即可得新数组该位置上的值代码如下:vector<int> productExceptSelf(vector<int>& nums) { int total=1; int num=0; int weizhi=-1; for(int i=0;i<nums.size();i++) { if(nums[i]!=0) total*=nums[i]; if(nums[i]==0) { num++; weizhi=i; } } vector<int> res(nums.size(),0); if(num>1) { return res; } else if(num==1) { res[weizhi]=total; return res; } else { for(int i=0;i<nums.size();i++) res[i]=total/nums[i]; return res; } return res; }
解题方法二:
我们分成两步,从前到后、从后往前。代码如下:int n=nums.size(); vector<int> res(n,1); for(int i=0;i<n;i++) { if(i==0) res[i]=1; else res[i]=res[i-1]*nums[i-1]; } int right=1; for(int i=n-1;i>=0;i--) { res[i]*=right; right*=nums[i]; } return res;
相关文章推荐
- leetcode[198]:House Robber
- hdoj 4556 Stern-Brocot Tree(欧拉函数)
- Python内置的字符串处理函数
- Hibernate——三种状态的实例persistent演示
- NGUI 3.5课程(五岁以下儿童)button-图片切换
- jQuery Validation Plugin
- 第一章:实验 访问命令行
- Looper与Handler解析
- acer v5 573g 黑苹果clover
- 【LeetCode 235_二叉搜索树】Lowest Common Ancestor of a Binary Search Tree
- [总结+题解]20141028
- POJ 1679 The Unique MST
- 基于javascript实现单选及多选的向右和向左移动实例
- 噩梦5Tilt Shift (Lens Blur) 倾斜移位(镜头模糊)
- chromium:LoadUrl之后会发生那些事情之OnDraw
- poj 3225 Help with Intervals(线段树区间更新)
- RTTI
- hdoj 2816 I Love You Too
- 以太网帧格式、IP数据报格式、TCP段格式+UDP段格式 详解
- A*算法—第K短路