面试算法-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;
    }
}
相关推荐
探索为何6 分钟前
JWT与Session的实战选择-杂谈(1)
后端·面试
怒放吧德德1 小时前
MySQL篇:MySQL主从集群同步延迟问题
后端·mysql·面试
算AI2 小时前
人工智能+牙科:临床应用中的几个问题
人工智能·算法
uhakadotcom3 小时前
MQTT入门:轻量级物联网通信协议
后端·面试·github
我不会编程5553 小时前
Python Cookbook-5.1 对字典排序
开发语言·数据结构·python
逆袭的小黄鸭3 小时前
JavaScript 闭包:强大特性背后的概念、应用与内存考量
前端·javascript·面试
carterwu3 小时前
如何自建一个类似antd的组件库?
面试
9号达人4 小时前
java9新特性详解与实践
java·后端·面试
owde4 小时前
顺序容器 -list双向链表
数据结构·c++·链表·list
uhakadotcom4 小时前
Zustand状态管理库:轻量级、高效的React解决方案
前端·javascript·面试