动态规划算法-子数组、子串系列(数组中连续的一段):21.乘积最大子数组

题目链接:152. 乘积最大子数组(中等)

算法原理:

解法:动态规划

Java代码:

java 复制代码
/**
 * Created with IntelliJ IDEA.
 * Description:
 * User: 王洋
 * Date: 2025-10-22
 * Time: 15:56
 */
class Solution {
    //152. 乘积最大子数组
    //看完算法原理自己没写出来,但是看完吴小哲写的又找不出错,好像确实是这回事
    public int maxProduct(int[] nums) {
        int n=nums.length;
        int[] f=new int[n+1];
        int[] g=new int[n+1];
        f[0]=g[0]=1;
        int ret=Integer.MIN_VALUE;
        for(int i=1;i<=n;i++){
            int x=nums[i-1],y=f[i-1]*nums[i-1],z=g[i-1]*nums[i-1];
            f[i]=Math.max(x,Math.max(y,z));
            g[i]=Math.min(x,Math.min(y,z));
            ret=Math.max(ret,f[i]);
        }
        return ret;
    }
}
相关推荐
laowangpython13 分钟前
Rust 入门:GitHub 热门内存安全编程语言
开发语言·其他·rust·github
我叫汪枫17 分钟前
在后台管理系统中,如何递归和选择保留的思路来过滤菜单
开发语言·javascript·node.js·ecmascript
_.Switch19 分钟前
东方财富股票数据JS逆向:secids字段和AES加密实战
开发语言·前端·javascript·网络·爬虫·python·ecmascript
软件技术NINI19 分钟前
webkit简介及工作流程
开发语言·前端·javascript·udp·ecmascript·webkit·yarn
Brendan_00119 分钟前
JavaScript的Stomp.over
开发语言·javascript·ecmascript
念23420 分钟前
f5 shape分析
开发语言·javascript·ecmascript
苍穹之跃24 分钟前
某量JS逆向
开发语言·javascript·ecmascript
思茂信息24 分钟前
CST软件如何进行参数化扫描?
运维·开发语言·javascript·windows·ecmascript·软件工程·软件需求
赈早见.琥珀猪24 分钟前
vue启动ReferenceError: ReadableStream is not defined
开发语言·javascript·ecmascript
爱吃牛肉的大老虎25 分钟前
JS异步中async、await讲解
开发语言·javascript·ecmascript