动态规划算法-子数组、子串系列(数组中连续的一段):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;
    }
}
相关推荐
趣知岛3 小时前
初识Java
java·开发语言
步菲4 小时前
springboot canche 无法避免Null key错误, Null key returned for cache operation
java·开发语言·spring boot
aigcapi9 小时前
RAG 系统的黑盒测试:从算法对齐视角解析 GEO 优化的技术指标体系
大数据·人工智能·算法
知远同学10 小时前
Anaconda的安装使用(为python管理虚拟环境)
开发语言·python
小徐Chao努力10 小时前
【Langchain4j-Java AI开发】09-Agent智能体工作流
java·开发语言·人工智能
CoderCodingNo10 小时前
【GESP】C++五级真题(贪心和剪枝思想) luogu-B3930 [GESP202312 五级] 烹饪问题
开发语言·c++·剪枝
柯慕灵10 小时前
7大推荐系统/算法框架对比
算法·推荐算法
adam-liu10 小时前
Fun Audio Chat 论文+项目调研
算法·语音端到端·fun-audio-chat
kylezhao201910 小时前
第1章:第一节 开发环境搭建(工控场景最优配置)
开发语言·c#
啃火龙果的兔子10 小时前
JavaScript 中的 Symbol 特性详解
开发语言·javascript·ecmascript