动态规划子数组系列一>乘积为正数的最长子数组长度

题目:


解析:


代码:

java 复制代码
public int getMaxLen(int[] nums) {
        int n = nums.length;
        int[] f = new int[n+1];
        int[] g = new int[n+1];

        int ret = -0x3f3f3f3f;
        for(int i = 1; i <= n; i++){
            if(nums[i-1] < 0){
                f[i] = g[i-1] == 0 ? 0 : g[i-1] + 1;
                g[i] = f[i-1] + 1;
            }
            else if(nums[i-1] > 0) {
                g[i] = g[i-1] == 0 ? 0 : g[i-1] + 1;
                f[i] = f[i-1] + 1;
            }
            
            ret = Math.max(ret,f[i]);
        }

        return ret;
    }
相关推荐
过河卒_zh15667666 分钟前
9.13AI简报丨哈佛医学院开源AI模型,Genspark推出AI浏览器
人工智能·算法·microsoft·aigc·算法备案·生成合成类算法备案
D.....l12 分钟前
冒泡排序与选择排序以及单链表与双链表
数据结构·算法·排序算法
sinat_2869451932 分钟前
Case-Based Reasoning用于RAG
人工智能·算法·chatgpt
Athenaand32 分钟前
代码随想录算法训练营第50天 | 图论理论基础、深搜理论基础、98. 所有可达路径、广搜理论基础
算法·图论
地平线开发者37 分钟前
征程 6 灰度图部署链路介绍
人工智能·算法·自动驾驶·汽车
徐子童3 小时前
优选算法---链表
数据结构·算法·链表·面试题
如意.7593 小时前
从零开始的指针(3)
算法
cwplh3 小时前
MX模拟赛总结
算法·动态规划