【152.乘积最大子数组】

目录

一、题目描述

二、算法原理

三、代码实现

cpp 复制代码
class Solution {
public:
    int maxProduct(vector<int>& nums) 
    {
        int n=nums.size();
        vector<int> f(n);
        vector<int> g(n);
        f[0]=g[0]=nums[0];
        int ret=nums[0];
        for(int i=1;i<n;i++)
        {
            f[i]=max(max(nums[i],nums[i]*f[i-1]),nums[i]*g[i-1]);
            g[i]=min(min(nums[i],nums[i]*f[i-1]),nums[i]*g[i-1]);
            ret=max(max(f[i],g[i]),ret);
        }
        return ret;

    }
};
相关推荐
敲代码的嘎仔2 分钟前
数据结构算法学习day3——二分查找
java·开发语言·数据结构·学习·程序人生·算法·职场和发展
晨非辰25 分钟前
《数据结构风云》:二叉树遍历的底层思维>递归与迭代的双重视角
数据结构·c++·人工智能·算法·链表·面试
Tisfy1 小时前
LeetCode 3217.从链表中移除在数组中存在的节点:哈希表(一次遍历)
leetcode·链表·散列表
小白菜又菜1 小时前
Leetcode 495. Teemo Attacking
算法·leetcode·职场和发展
.柒宇.7 小时前
力扣hot100----15.三数之和(java版)
java·数据结构·算法·leetcode
杰克尼8 小时前
二分查找为什么总是写错
java·数据结构·算法
程序员阿鹏11 小时前
56.合并区间
java·数据结构·算法·leetcode
古译汉书12 小时前
Stm32江科大入门教程--各章节详细笔记---查阅传送门
数据结构·stm32·单片机·嵌入式硬件·算法
Jasmine_llq14 小时前
《P2656 采蘑菇》
算法·强连通分量·广度优先搜索(bfs)·tarjan 算法·图的缩点操作·有向无环图(dag)·最长路径