zoukankan      html  css  js  c++  java
  • 刷题152. Maximum Product Subarray

    一、题目说明

    题目152. Maximum Product Subarray,给一列整数,求最大连续子序列,其乘积最大。难度是Medium!

    二、我的解答

    这个题目,用双重循环就可以了。

    class Solution{
    	public:
    		int maxProduct(vector<int>& nums){
    			if(nums.size()<=1) return nums[0];
    			product = INT_MIN;
    			int len = nums.size();
    			
    			for(int i=0;i<len;i++){
    				int p = nums[i];
    				if(p>product) product = p;
    				for(int t=i+1;t<len;t++){
    					p *= nums[t];
    					if(p>product) product = p;
    				}
    			}
    			return product;
    		}
    	private:
    		int product;
    };
    

    性能如下:

    Runtime: 200 ms, faster than 6.16% of C++ online submissions for Maximum Product Subarray.
    Memory Usage: 9.1 MB, less than 82.50% of C++ online submissions for Maximum Product Subarray.
    

    三、优化措施

    仔细再读读题目,一列整数,上述方法太“通用”,一次循环就可以了。

    class Solution{
    	public:
    		//dp,其中dp[i]表示以第i个元素结尾的最大乘积 
    		int maxProduct(vector<int>& nums){
    			if(nums.size()<=1) return nums[0];
    			dpMax = nums[0];
    			dpMin = nums[0];
    			maxProd = nums[0];
    			int len = nums.size();
    			
    			for(int i=1;i<len;i++){
    				int preMax = dpMax;
    				dpMax = max(dpMin*nums[i],max(nums[i],dpMax*nums[i]));
    				dpMin = min(dpMin*nums[i],min(preMax*nums[i],nums[i]));
    				cout<<"i="<<i<<",dpMax="<<dpMax<<",dpMin="<<dpMin<<"
    "; 
    				maxProd = max(dpMax,maxProd);
    			}
    			return maxProd;
    		}
    	private:
    		int dpMax;
    		int dpMin;
    		int maxProd;
    };
    
    Runtime: 16 ms, faster than 9.45% of C++ online submissions for Maximum Product Subarray.
    Memory Usage: 9.1 MB, less than 75.00% of C++ online submissions for Maximum Product Subarray.
    
    所有文章,坚持原创。如有转载,敬请标注出处。
  • 相关阅读:
    WinCE 手机互联
    Android 之 getSharedPreferences 和 getPreferences
    Android 之 ListView 点击响应代码?
    Android 之 selector
    昨天晚上被 Android 手机上的广告程序折磨了
    今天终于将第一个 Android NDK 程序编译、运行成功
    Android 4.0.1 源代码编译
    The connection to adb is down, and a severe error has occured.
    成绩转换
    兄弟郊游问题
  • 原文地址:https://www.cnblogs.com/siweihz/p/12275502.html
Copyright © 2011-2022 走看看