面试算法-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;
    }
}
相关推荐
普通网友1 分钟前
C++中的适配器模式
开发语言·c++·算法
普通网友23 分钟前
C++中的委托构造函数
开发语言·c++·算法
普通网友39 分钟前
C++中的代理模式实战
开发语言·c++·算法
普通网友1 小时前
C++模块化设计原则
开发语言·c++·算法
倦王1 小时前
力扣日刷251117
算法·leetcode·职场和发展
Genevieve_xiao2 小时前
【数据结构】【xjtuse】八股文单元小测
数据结构·算法
Xの哲學2 小时前
Linux slab分配器深度剖析:从原理到实践
linux·服务器·算法·架构·边缘计算
S***t7142 小时前
程序员跳槽3次,我总结的面试技巧 **程序员跳槽3次,我总结的面试技巧**
面试·职场和发展·跳槽
普通网友3 小时前
C++中的组合模式
开发语言·c++·算法
2501_941111463 小时前
C++中的组合模式变体
开发语言·c++·算法