152. Maximum Product Subarray
来源:互联网 发布:电子数据交换业务 编辑:程序博客网 时间:2024/04/26 15:49
Find the contiguous subarray within an array (containing at least one number) which has the largest product.
For example, given the array [2,3,-2,4]
,
the contiguous subarray [2,3]
has the largest product = 6
.
思路:max(n) = max{ max(n-1), product(...n) }, product是连续乘积到n的最大正值(包含a[n]的连续最大乘积)。所以需记录连续乘积到n-1的最大的正负值。
class Solution {public:int maxProduct(vector<int>& nums) {if (nums.size() < 1)return 0;int maxNum = (numeric_limits<int>::min)();int positive = 1;int negative = 1;for (int i = 0; i < nums.size(); i++){if (nums[i] >= 0){positive *= nums[i];negative *= nums[i];}else{int tmp = positive;positive = negative * nums[i];negative = tmp * nums[i];}if (positive > maxNum)maxNum = positive;if (positive <= 0)positive = 1;if (negative >= 0)negative = 1;}return maxNum;}};
0 0
- 152. Maximum Product Subarray
- 152. Maximum Product Subarray
- 152. Maximum Product Subarray
- 152. Maximum Product Subarray
- 152. Maximum Product Subarray
- 152. Maximum Product Subarray
- 152. Maximum Product Subarray
- 152. Maximum Product Subarray
- 152. Maximum Product Subarray
- 152. Maximum Product Subarray
- 152. Maximum Product Subarray
- 152. Maximum Product Subarray
- 152. Maximum Product Subarray
- 152. Maximum Product Subarray
- 152. Maximum Product Subarray
- 152. Maximum Product Subarray
- 152. Maximum Product Subarray
- 152. Maximum Product Subarray
- 【WCF】深入理解配置文件
- 单循环链表(C语言实现)
- python入门基础知识
- 谈一谈事物之间的关联(一)——空间与时间
- hdu4587(去掉两个点让强连通分量最大)
- 152. Maximum Product Subarray
- 运算符重载2
- hive JDBC连接示例
- 《JAVA继承与多态》【Person、Student、Employee类】(注:此题在书上原题基础上有修改)设计一个名为Person的类和它的两个名为Student和Employee子类。
- 在Windows上玩TensorFlow(一)——安装Docker
- 4种方法让SpringMVC接收多个对象
- String——求没有重复字符的最长的子串
- js实现排序算法(冒泡、选择、插入、二分插入、快速、希尔)
- Python爬取豆瓣电影Top250数据