动态规划——最大连续子数组和(或乘积)

public static int maxSubArray(int[] nums) {
		if (nums == null || nums.length == 0)
			return 0;
		int curr = 0;
		int sum = Integer.MIN_VALUE;
		for (int i = 0; i < nums.length; i++) {
			curr += nums[i];
			if (sum < curr)
				sum = curr;
			if (curr < 0)
				curr = 0;
		}
		return sum;
	}
	
	//更标准的动态规划写法
	public int maxSubArray_2(int[] A) {  
	    if(A==null || A.length==0)  
	        return 0;  
	    int global = A[0];  
	    int local = A[0];  
	    for(int i=1;i<A.length;i++)  
	    {  
	        local = Math.max(A[i],local+A[i]);  
	        global = Math.max(local,global);  
	    }  
	    return global;  
	}  


变式:求最大连续子数组乘积

思路:

维护三个变量,分别记录i-1结尾的最大累乘积、i-1结尾的最小累乘积、全局最大值;我们考虑以i结尾的子数组的最大乘积,有以下三种情况:

a. i上的乘积就是i-1位置的最大乘积*arr【i】  比如 100 10 2

b. i上的乘积就是i-1位置的最小乘积*arr【i】  比如 100 -10 -2

c. 自己构成的子数组最大(前面是<1的情况)比如 0.1  0.1  100

public int maxProduct(int[] nums) {
		if(nums==null||nums.length==0)
			return 0;
		int subMax[]=new int[nums.length];
		int subMin[]=new int[nums.length];
		subMax[0]=nums[0];
		subMin[0]=nums[0];
		int res=nums[0];
		for(int i=1;i<nums.length;i++){
			subMax[i]=Math.max(Math.max(nums[i],subMax[i-1]*nums[i]),subMin[i-1]*nums[i]);
			subMin[i]=Math.min(Math.min(nums[i],subMax[i-1]*nums[i]),subMin[i-1]*nums[i]);
			
			res=Math.max(res,subMax[i]);
		}
		return res;
    }



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值