Leetcode刷题详解——乘积为正数的最长子数组长度

1. 题目链接:1567. 乘积为正数的最长子数组长度

2. 题目描述:

给你一个整数数组 nums ,请你求出乘积为正数的最长子数组的长度。

一个数组的子数组是由原数组中零个或者更多个连续数字组成的数组。

请你返回乘积为正数的最长子数组长度。

示例 1:

输入:nums = [1,-2,-3,4]
输出:4
解释:数组本身乘积就是正数,值为 24 。

示例 2:

输入:nums = [0,1,-2,-3,-4]
输出:3
解释:最长乘积为正数的子数组为 [1,-2,-3] ,乘积为 6 。
注意,我们不能把 0 也包括到子数组中,因为这样乘积为 0 ,不是正数。

示例 3:

输入:nums = [-1,-2,-3,0,1]
输出:2
解释:乘积为正数的最长子数组是 [-1,-2] 或者 [-2,-3] 。

提示:

  • 1 <= nums.length <= 10^5
  • -10^9 <= nums[i] <= 10^9

3. 解法(动态规划)

3.1 算法思路:

1. 状态表示:

f[i]表示:以i结尾的所有子数组中,乘积为正数的最长子数组的长度

g[i]表示:以i结尾的所有子数组中,乘积为负数的最长子数组的长度

2. 状态转移方程:

请添加图片描述

3. 初始化:

可以在最前面加上一个辅助结点,帮助我们完成初始化,使用这种技巧要注意两个点:

  1. 辅助结点里面的值要保证后续填表是正确的
  2. 下标的映射关系

在本题中,最起码加上一个格子,并且让 f[0]=g[0]=0即可‘

请添加图片描述

4. 填表顺序:

根据状态转移方程,填表顺序为从左往右,两个表一块填

5. 返回值:

根据状态表示,我们要返回f表中的最大值

3.2 C++算法代码:

class Solution {
public:int getMaxLen(vector<int>& nums) {int n = nums.size(); // 获取数组长度vector<int> f(n + 1), g(n + 1); // 初始化两个辅助数组f和g,长度为n+1int ret = INT_MIN; // 初始化结果变量ret为最小整数for (int i = 1; i <= n; i++) {if (nums[i - 1] > 0) { // 如果当前元素大于0f[i] = f[i - 1] + 1; // 更新f数组的当前元素为前一个元素加1g[i] = g[i - 1] == 0 ? 0 : g[i - 1] + 1; // 更新g数组的当前元素为前一个元素加1,如果前一个元素为0则保持不变} else if (nums[i - 1] < 0) { // 如果当前元素小于0f[i] = g[i - 1] == 0 ? 0 : g[i - 1] + 1; // 更新f数组的当前元素为前一个元素加1,如果前一个元素为0则保持不变g[i] = f[i - 1] + 1; // 更新g数组的当前元素为前一个元素加1}ret = max(ret, f[i]); // 更新结果变量ret为f数组中的最大值}return ret; // 返回结果变量ret}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/194963.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

什么是结构化数据?哪些OCR软件可将图片文字转为结构化数据?

结构化数据是指按照一定的数据模型组织和存储的数据&#xff0c;具有明确的数据类型和数据关系&#xff0c;并且可通过计算机程序进行处理和分析。这种数据通常存储在定义明确的模式中&#xff0c;例如数据库&#xff0c;采用表格的形式存储&#xff0c;每个数据项都有特定的字…

Mover Creator 用户界面

1 “开始”对话框 首次打开 Mover Creator 时&#xff0c;出现的第一个页面是“开始”对话框&#xff0c;如下所示。从这里开始&#xff0c;用户可以选择开始设计飞机、武器或发动机。在上述每种情况下&#xff0c;用户都可以创建新模型或编辑现有模型。 1.1 新建模型 如果用…

Apache Doris 详细教程(二)

5、doris的查询语法 5.1、doris查询语法整体结构 SELECT [ALL | DISTINCT | DISTINCTROW ] -- 对查询字段的结果是否需要去重&#xff0c;还是全部保留等参数 select_expr [, select_expr ...] -- select的查询字段 [FROM table_references [PARTITION…

94基于matlab的蚁群算法 (ACO) 对付的图像边缘检测问题

基于matlab的蚁群算法 (ACO) 对付的图像边缘检测问题。提出基于蚁群算法的边缘检测方法是能够建立一个信息素矩阵表示提出了一种在图像每个像素位置的边缘信息根据大量的蚂蚁的运动有哪些派去在图像上移动。此外&#xff0c;运动这些蚂蚁是由图像的局部变化驱动强度值。数据可更…

U1编译概述

文章目录 基本概念定义一些概念 编译流程词法分析语法分析语义分析、生成中间代码中间代码 代码优化生成目标程序五个阶段中都需要做的两件事符号表管理出错处理 总结 其他概念多层中间表示和遍&#xff08;PASS&#xff09;三端模式课程概述 基本概念 定义 用高级语言编制的…

【Java 基础】18 I/O流

文章目录 1.基本概念2.字节流3.字符流4.标准输入输出5.最佳实践 I/O流&#xff08;Input/Output 流&#xff09;是计算机程序中不可或缺的一部分&#xff0c; 往大了说所有的操作都是IO。Java 提供了强大而灵活的 I/O 框架&#xff0c;支持各种数据的 读取和 写入操作。 1.基…

45 - 多线程性能优化常见问题

1、使用系统命令查看上下文切换 上下文切换常见的监测工具 1.1、Linux 命令行工具之 vmstat 命令 vmstat 是一款指定采样周期和次数的功能性监测工具&#xff0c;我们可以使用它监控进程上下文切换的情况。 vmstat 1 3 命令行代表每秒收集一次性能指标&#xff0c;总共获取 …

day5 两数之和为x

vector<int> twoSum(vector<int>& nums, int target) { std::unordered_map <int,int> map; for(int i 0; i < nums.size(); i) { // 遍历当前元素&#xff0c;并在map中寻找是否有匹配的key auto iter map.find(target - nums[i]); if(iter ! map…

【JavaSE】:String(二):深入String

深入String 一.字符串的存储二.字符串的不可变性三.字符串修改四.StringBuilder和StringBuffer 一.字符串的存储 我们知道双引号里的数据都是字符串常量&#xff0c;储存在字符串常量池当中。 例子 直接使用是比较地址。字符串常量池有一个特点&#xff1b;它会先检查该常量是否…

LLM-Intro to Large Language Models

LLM some LLM’s model and weight are not opened to user what is? Llama 270b model 2 files parameters file parameter or weight of neural networkparameter – 2bytes, float number code run parameters(inference) c or python, etcfor c, 500 lines code withou…

智能制造热点词汇科普篇——LaaS、SaaS、PaaS

随着智能制造的不断普及&#xff0c;越来越多的制造企业选择进行数字化转型增强自身的综合竞争力。自动化、信息化、智能化是实现数字化转型的三个重要步骤&#xff0c;在进行对企业的充分调研后&#xff0c;选择适合自己的自动化设备、信息化软件&#xff0c;最后与各种智能化…

中介者模式 rust和java的实现

文章目录 中介者模式介绍实现javarustrust仓库 中介者模式 中介者模式&#xff08;Mediator Pattern&#xff09;又被称为 调停者模式 。 它定义了一个中介对象来封装一系列对象之间的交互关系。 中介者使各个对象之间不需要显式地相互引用&#xff0c;从而使耦合性降低&#…

VMware Workstation unrecoverable error: (vmx)

问题: 我将虚拟机挂起后,电脑关机了,再打开时无法恢复虚拟机,查看日志后发现以下错误 2023-12-04T00:35:53.070Z In(05) vmx Msg_Post: Error 2023-12-04T00:35:53.070Z In(05) vmx [msg.log.error.unrecoverable] VMware Workstation unrecoverable error: (vmx) 2023-12-04T…

计算机网络扫盲(4)——时延

一、概述 在这里&#xff0c;我们考虑分组交换网的情况&#xff0c;因特网可以被看成是一种基础设施&#xff0c;该基础设施为运行在端系统上的分布式应用提供服务。在理想情况下&#xff0c;我们希望因特网服务能够在任意两个端系统之间随心所欲地移动数据而没有任何数据地丢失…

韩语图片文字如何转为纯文本?

如何将上图为韩语的图片转为文本文件&#xff1f;这个需要用到OCR程序&#xff0c;操作方法如下&#xff1a; 一、打开金鸣识别网站。 二、点击“点击添加图片/PDF”&#xff0c;将待识别的图片添加到列表。 三、识别模块点选“通用文字”&#xff0c;输出格式选择“纯文本输出…

陀螺仪LSM6DSV16X与AI集成(1)----轮询获取陀螺仪数据

陀螺仪LSM6DSV16X与AI集成.1--轮询获取陀螺仪数据 概述视频教学样品申请通信模式管脚定义IIC通信模式速率生成STM32CUBEMX串口配置IIC配置CS和SA0设置串口重定向参考程序初始换管脚获取ID复位操作BDU设置设置量程和速率配置过滤链轮询读取数据主程序演示 概述 本文将介绍如何使…

脏读、不可重复读、幻读

一、脏读 A事务读取B事务尚未提交的数据&#xff0c;此时如果B事务发生错误并执行回滚操作&#xff0c;那么A事务读取到的数据就是脏数据。就好像原本的数据比较干净、纯粹&#xff0c;此时由于B事务更改了它&#xff0c;这个数据变得不再纯粹。这个时候A事务立即读取了这个脏…

Python链表排序相关问题解法

1 问题 链表实现选择排列中经常会遇到一些问题&#xff0c;那么该如何解决它们呢&#xff1f; 2 方法 这一类问题的基本都是根据题目给定的条件&#xff0c;对链表进行各种组合&#xff0c;如&#xff1a;基于归并排序思想&#xff0c;根据节点的数值&#xff0c;合并两个链表&…

PPT设置背景颜色

问题描述&#xff1a;PPT如何设置背景颜色&#xff1f; 问题解决&#xff1a;设计→设置背景格式→颜色→蓝色&#xff08;最好选择看着比较舒服的颜色&#xff09;

131. 分割回文串

题目描述 给你一个字符串 s&#xff0c;请你将 s 分割成一些子串&#xff0c;使每个子串都是 回文串 。返回 s 所有可能的分割方案。 回文串 是正着读和反着读都一样的字符串。 示例 1&#xff1a; 输入&#xff1a;s "aab" 输出&#xff1a;[["a",&q…