【1567.乘积为正数的最长子数组长度】

目录

一、题目描述

二、算法原理

三、代码实现

cpp 复制代码
class Solution {
public:
    int getMaxLen(vector<int>& nums) 
    {
        int n=nums.size();
        vector<int> f(n);
        vector<int> g(n);
        f[0]=nums[0]>0?1:0;
        g[0]=nums[0]<0?1:0;
        int ret=f[0];
        for(int i=1;i<n;i++)
        {
            if(nums[i]>0)  
            {
                f[i]=1+f[i-1];
                g[i]=g[i-1]==0?0:1+g[i-1];
            }
            else if(nums[i]<0)
            {
                f[i]=g[i-1]>0?1+g[i-1]:0;
                g[i]=1+f[i-1];
            }
            ret=max(f[i],ret);
        }
        return ret;
    }
};
相关推荐
挠头猴子1 分钟前
一个数组去重,两个数组找不同或相同
数据结构·算法
big_rabbit050214 分钟前
[算法][力扣167]Two Sum II
算法·leetcode·职场和发展
颜酱23 分钟前
二分图核心原理与判定算法
javascript·后端·算法
筱砚.42 分钟前
C++——lambda
开发语言·c++·算法
Eward-an1 小时前
LeetCode 76. 最小覆盖子串(详细技术解析)
python·算法·leetcode·职场和发展
guygg881 小时前
基于ADMM的MRI-PET高质量图像重建算法MATLAB实现
开发语言·算法·matlab
moonlight03041 小时前
类加载子系统
java·jvm·算法
baivfhpwxf20231 小时前
ACS X轴回零程序 项目实战版
网络·数据库·算法
一叶落4381 小时前
LeetCode 219. 存在重复元素 II(C语言详解)
算法·哈希算法·散列表
像污秽一样1 小时前
算法设计与分析-习题2.4
数据结构·算法·排序算法