C++ 连续子数组的最大乘积

描述

输入一个长度为n的整型数组nums,数组中的一个或连续多个整数组成一个子数组。求所有子数组的乘积的最大值。

1.子数组是连续的,且最小长度为1,最大长度为n

2.长度为1的子数组,乘积视为其本身,比如[4]的乘积为4

3.该题的数据保证最大的乘积不会超过int的范围

数据范围: −100<=𝑎[𝑖]<=100−100<=a[i]<=100

示例1

输入:

复制代码
[3,2,-1,4]

返回值:

复制代码
6

说明:

复制代码
子数组[3,2]的乘积为6,[3,2,-1,4]的乘积为-24,[4]的乘积为4,故返回6
cpp 复制代码
#include <vector>
class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param nums int整型vector 
     * @return int整型
     */
    int maxProduct(vector<int>& nums) {
        // write code here
        if(nums.empty())
        {
            return 0;
        }

        int n = nums.size();   
        std::vector<int> dp_max(n, 0);
        std::vector<int> dp_min(n, 0);
     
        dp_max[0] = nums[0];
        dp_min[0] = nums[0];

        int res = nums[0]; 
        for(int i = 1; i < n; i++)
        {
            dp_max[i] = std::max(nums[i],  std::max(dp_max[i-1] * nums[i], dp_min[i-1]*nums[i]));
            dp_min[i] = std::min(nums[i], std::min(dp_max[i-1]*nums[i], dp_min[i-1]*nums[i]));

            res = std::max(res, dp_max[i]);
        }
        return res;
    }
};
相关推荐
MSTcheng.10 分钟前
【C++STL】priority_queue 模拟实现与仿函数实战
开发语言·c++
还有几根头发呀19 分钟前
从 C++ 的角度,系统地解释 进程(Process)、线程(Thread)、协程(Coroutine) 的概念、原理、优缺点,以及常见应用场景。
c++
oioihoii23 分钟前
Python与C++:从哲学到细节的全面对比
c++
小年糕是糕手28 分钟前
【C++】C++入门 -- inline、nullptr
linux·开发语言·jvm·数据结构·c++·算法·排序算法
高洁0140 分钟前
具身智能-普通LLM智能体与具身智能:从语言理解到自主行动
人工智能·深度学习·算法·aigc·知识图谱
kk哥889941 分钟前
Keil MDK 5.39 编程 + 调试 ,ARM 嵌入式开发!如何安装
c++·arm
重启的码农1 小时前
enet源码解析 (2) 对等节点 (ENetPeer)
c++·网络协议
星期天21 小时前
3.2联合体和枚举enum,还有动态内存malloc,free,calloc,realloc
c语言·开发语言·算法·联合体·动态内存·初学者入门·枚举enum
塞北山巅1 小时前
camera hal层(AF)
c++·camera
Andy1 小时前
回文子串数目--动态规划算法
算法·动态规划