面试算法-104-乘积最大子数组

题目

给你一个整数数组 nums ,请你找出数组中乘积最大的非空连续

子数组

(该子数组中至少包含一个数字),并返回该子数组所对应的乘积。

测试用例的答案是一个 32-位 整数。

示例 1:

输入: nums = [2,3,-2,4]

输出: 6

解释: 子数组 [2,3] 有最大乘积 6。

java 复制代码
class Solution {
    public int maxProduct(int[] nums) {
        int n = nums.length;
        int[][] dp = new int[n][2];

        dp[0][0] = nums[0];
        dp[0][1] = nums[0];
        int max = nums[0];
        for (int i = 1; i < n; i++) {
            if (nums[i] > 0) {
                dp[i][0] = Math.max(nums[i], dp[i - 1][0] * nums[i]);
                dp[i][1] = Math.min(nums[i], dp[i - 1][1] * nums[i]);
            } else {
                dp[i][0] = Math.max(nums[i], dp[i - 1][1] * nums[i]);
                dp[i][1] = Math.min(nums[i], dp[i - 1][0] * nums[i]);
            }
            max = Math.max(max, dp[i][0]);
        }
        return max;
    }
}
相关推荐
CoovallyAIHub几秒前
南京理工大学联手百度、商汤科技等团队推出Artemis:用结构化视觉推理革新多模态感知
深度学习·算法·计算机视觉
扣丁梦想家2 分钟前
面试基础整理之 ArrayList
面试·职场和发展
天才少女爱迪生3 分钟前
图像序列预测有什么算法方案
人工智能·python·深度学习·算法
GSDjisidi3 分钟前
日本IT行业|一些it資格证书分享解析,一篇通读
开发语言·面试·职场和发展
cici158745 分钟前
3D有限元直流电阻率法正演程序
算法·3d
陈陈爱java8 分钟前
综合素质面试hr面
面试·职场和发展
黑色的山岗在沉睡9 分钟前
滤波算法数学前置——线性化
线性代数·算法
t1987512812 分钟前
火电机组热经济性分析MATLAB程序实现
人工智能·算法·matlab
Hello娃的20 分钟前
【半导体】肖特基接触AND欧姆接触
人工智能·算法
橘颂TA21 分钟前
【剑斩OFFER】算法的暴力美学——交易逆序对的总数
数据结构·算法·leetcode