首页 > 其他 > 详细

[LeetCode] Maximum Product Subarray

时间:2015-07-06 19:43:40      阅读:214      评论:0      收藏:0      [点我收藏+]

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.

 

Hide Tags
 Array Dynamic Programming
 
 
参考 http://www.cnblogs.com/diegodu/p/4589796.html
class Solution {
public:
    int maxProduct(vector<int>& arr) {

            if(arr.size() == 0)
                return 0;
            int minVal = arr[0];
            int maxVal = arr[0];
            int rtn = arr[0];
 
            int tmpMax = 0;
            int tmpMin = 0;
 
            for(int i = 1; i < arr.size(); i++)
            {  
                //cout << "max\t" << maxVal << endl;
                //cout << "min\t" << minVal << endl;
                tmpMax = max(maxVal * arr[i], minVal * arr[i]);
                tmpMin = min(maxVal * arr[i], minVal * arr[i]);
 
                maxVal = max(tmpMax, arr[i]);
                minVal = min(tmpMin, arr[i]);
 
                rtn = max(rtn, maxVal);
            }  
            return rtn;
        }  
};

 

[LeetCode] Maximum Product Subarray

原文:http://www.cnblogs.com/diegodu/p/4625018.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!