【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;
    }
};
相关推荐
cpp_2501几秒前
P10109 [GESP202312 六级] 工作沟通
数据结构·c++·算法·题解·洛谷·gesp六级
吴可可123几秒前
CAD二次开发中多段线定点分割技巧
算法
ʚ希希ɞ ྀ4 分钟前
全排列 --- 回溯
算法·leetcode·深度优先
玉树临风ives4 分钟前
atcoder ABC 460 题解
数据结构·c++·算法
水无痕simon5 分钟前
9 C语言的基础练习
c语言·开发语言·算法
8Qi810 分钟前
LeetCode 124. 二叉树中的最大路径和(Hard)
算法·leetcode·二叉树·递归
And_Ii15 分钟前
LeetCode 1. 两数之和 python
数据结构·算法·leetcode
東隅已逝,桑榆非晚21 分钟前
C语言预处理详解:从宏到条件编译
c语言·笔记·算法
cpp_250125 分钟前
P10377 [GESP202403 六级] 好斗的牛
数据结构·c++·算法·题解·洛谷·gesp六级
邪修king25 分钟前
C++ 红黑树自平衡核心:旋转变色、规则详解与 STL 选型逻辑
数据结构·c++·b树·算法