码迷,mamicode.com
首页 > 其他好文 > 详细

[LeetCode]152. 乘积最大子序列(DP)

时间:2020-02-12 09:21:06      阅读:62      评论:0      收藏:0      [点我收藏+]

标签:for   表示   leetcode   准备   链接   数组   com   ret   题目   

题目

给定一个整数数组 nums?,找出一个序列中乘积最大的连续子序列(该序列至少包含一个数)。

示例 1:

输入: [2,3,-2,4]
输出: 6
解释:?子数组 [2,3] 有最大乘积 6。
示例 2:

输入: [-2,0,-1]
输出: 0
解释:?结果不能为 2, 因为 [-2,-1] 不是子数组。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/maximum-product-subarray
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

题解

DP

  • 状态:
    dpMax[i]表示以nums[i]为结尾的子数组的最大乘积
    dpMin[i] 表示以nums[i]为结尾的子数组的最小乘积,为计算dpMax[i+1]且nume[i+1]<0情况做准备
    由于只遍历一遍,所以两状态可用两变量存足以

  • 状态转移方程
dpMax = Math.max(dpMax * num, num),nums[i]>=0
dpMax = Math.max(dpMin * num, num), nums[i]<=0
  • 注意更新dpMax与dpMin时分清新旧,必要时使用临时变量存一下

代码

class Solution {
    public  int maxProduct(int[] nums) {
        int dpMax = 1;
        int dpMin = 1;
        int max = Integer.MIN_VALUE;
        for (int num : nums) {
            if (num > 0) {
                dpMax = Math.max(dpMax * num, num);
                dpMin = Math.min(dpMin * num, num);
            } else {
                int dpMaxTmp = dpMax;//
                dpMax = Math.max(dpMin * num, num);
                dpMin = Math.min(dpMaxTmp * num, num);//
            }
            max = Math.max(max, dpMax);
        }
        return max;
    }
}

[LeetCode]152. 乘积最大子序列(DP)

标签:for   表示   leetcode   准备   链接   数组   com   ret   题目   

原文地址:https://www.cnblogs.com/coding-gaga/p/12297487.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!