【Leetcode乘积最大子序列】152. 乘积最大子数组(子序列连续)

Leetcode152

1.问题描述

在这里插入图片描述

2.解决方案

1.状态转移方程没那么简单,最优状态不一定来源于dp[n-1]×nums[i]和nums[i]最大值,如果是负数,那可能和前面的最小值乘起来更大
2.所以要维护两个dp数组,一个是以i结尾最大子数组和最小子数组,这个是因为乘积本身就比较特殊
3.最简单的思考方式,就是分情况讨论,如果一个数是正数,那么以它结尾最大,那肯定希望是一个最大正数,如果一个数是负数,那以它结尾最大,那肯定希望是一个最小负数

在这里插入图片描述

package leetcode;

public class lc152 {
   
    public int maxProduct(int[] nums) {
   
        if(n
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值