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;
    }
};
相关推荐
郭涤生4 小时前
布隆过滤器
c++
智者知已应修善业4 小时前
【求中位数】2024-1-23
c语言·c++·经验分享·笔记·算法
9ilk4 小时前
【C++】--- 特殊类设计
开发语言·c++·后端
地平线开发者5 小时前
PTQ 量化数值范围与优化
算法·自动驾驶
sali-tec5 小时前
C# 基于halcon的视觉工作流-章68 深度学习-对象检测
开发语言·算法·计算机视觉·重构·c#
测试人社区-小明5 小时前
智能弹性伸缩算法在测试环境中的实践与验证
人工智能·测试工具·算法·机器学习·金融·机器人·量子计算
罗西的思考6 小时前
【Agent】MemOS 源码笔记---(5)---记忆分类
人工智能·深度学习·算法
程序员zgh8 小时前
Linux系统常用命令集合
linux·运维·服务器·c语言·开发语言·c++
獭.獭.8 小时前
C++ -- STL【unordered_set与unordered_map的实现】
开发语言·c++·unordered_map·unordered_set
qq_433554549 小时前
C++数位DP
c++·算法·图论