Leetcode.2369 检查数组是否存在有效划分

题目链接

Leetcode.2369 检查数组是否存在有效划分 rating : 1780

题目描述

给你一个下标从 0 0 0 开始的整数数组 n u m s nums nums ,你必须将数组划分为一个或多个 连续 子数组。

如果获得的这些子数组中每个都能满足下述条件 之一 ,则可以称其为数组的一种 有效 划分:

  1. 子数组 2 2 2 个相等元素组成,例如,子数组 [ 2 , 2 ] [2,2] [2,2]
  2. 子数组 3 3 3 个相等元素组成,例如,子数组 [ 4 , 4 , 4 ] [4,4,4] [4,4,4]
  3. 子数组 3 3 3 个连续递增元素组成,并且相邻元素之间的差值为 1 1 1 。例如,子数组 [ 3 , 4 , 5 ] [3,4,5] [3,4,5] ,但是子数组 [ 1 , 3 , 5 ] [1,3,5] [1,3,5] 不符合要求。

如果数组 至少 存在一种有效划分,返回 true ,否则,返回 false

示例 1:

输入:nums = [4,4,4,5,6]
输出:true
解释:数组可以划分成子数组 [4,4] 和 [4,5,6] 。
这是一种有效划分,所以返回 true 。

示例 2:

输入:nums = [1,1,1,2]
输出:false
解释:该数组不存在有效划分。

提示:
  • 2 ≤ n u m s . l e n g t h ≤ 1 0 5 2 \leq nums.length \leq 10^5 2nums.length105
  • 1 ≤ n u m s [ i ] ≤ 1 0 6 1 \leq nums[i] \leq 10^6 1nums[i]106

解法:dp

我们定义 f ( i ) f(i) f(i) 考虑 n u m s nums nums 中的前 i i i 个数是否存在有效划分。根据定义, n u m s nums nums n n n 个元素,那么 f ( n ) f(n) f(n) 就是最终要返回的答案。

我们直接考虑前 i i i 个数:

  1. 如果 i ≥ 2 i \geq 2 i2 并且 n u m s [ i ] = n u m s [ i − 1 ] nums[i] = nums[i - 1] nums[i]=nums[i1],那么 f [ i ] = f [ i − 2 ] f[i] = f[i - 2] f[i]=f[i2]
  2. 如果 i ≥ 3 i \geq 3 i3
  • 如果 n u m s [ i − 2 ] = n u m s [ i − 1 ] a n d n u m s [ i − 1 ] = n u m s [ i ] nums[i-2]=nums[i-1]\ and\ nums[i-1]=nums[i] nums[i2]=nums[i1] and nums[i1]=nums[i],那么 f [ i ] = f [ i − 3 ] f[i] = f[i - 3] f[i]=f[i3]
  • 如果 n u m s [ i − 2 ] + 1 = n u m s [ i − 1 ] a n d n u m s [ i − 1 ] + 1 = n u m s [ i ] nums[i-2]+1=nums[i-1]\ and\ nums[i-1]+1=nums[i] nums[i2]+1=nums[i1] and nums[i1]+1=nums[i],那么 f [ i ] = f [ i − 3 ] f[i] = f[i - 3] f[i]=f[i3]

只要上述三种情况有一个为真,那么 f [ i ] f[i] f[i] 就为真!

初始时, f [ 0 ] = t r u e f[0] = true f[0]=true,即没有元素也是一种有效划分!

注意: f [ 1 ] f[1] f[1] 表示第一个元素,而 n u m s [ 0 ] nums[0] nums[0] 表示第一个元素。所以关于 n u m s nums nums ,下标都要减 1 1 1

最终:

  1. 如果 i ≥ 2 i \geq 2 i2 并且 n u m s [ i − 1 ] = n u m s [ i − 2 ] nums[i - 1] = nums[i - 2] nums[i1]=nums[i2],那么 f [ i ] = f [ i − 2 ] f[i] = f[i - 2] f[i]=f[i2]
  2. 如果 i ≥ 3 i \geq 3 i3
  • 如果 n u m s [ i − 3 ] = n u m s [ i − 2 ] a n d n u m s [ i − 2 ] = n u m s [ i − 1 ] nums[i-3]=nums[i-2]\ and\ nums[i-2]=nums[i-1] nums[i3]=nums[i2] and nums[i2]=nums[i1],那么 f [ i ] = f [ i − 3 ] f[i] = f[i - 3] f[i]=f[i3]
  • 如果 n u m s [ i − 3 ] + 1 = n u m s [ i − 2 ] a n d n u m s [ i − 2 ] + 1 = n u m s [ i − 1 ] nums[i-3]+1=nums[i-2]\ and\ nums[i-2]+1=nums[i-1] nums[i3]+1=nums[i2] and nums[i2]+1=nums[i1],那么 f [ i ] = f [ i − 3 ] f[i] = f[i - 3] f[i]=f[i3]

时间复杂度: O ( n ) O(n) O(n)

C++代码:

class Solution {
public:bool validPartition(vector<int>& nums) {int n = nums.size();vector<int> f(n + 1);f[0] = 1;for(int i = 2;i <= n;i++){if(nums[i - 1] == nums[i - 2]) f[i] |= f[i - 2];if(i >= 3){if(nums[i - 1] == nums[i - 2] && nums[i - 2] == nums[i - 3]) f[i] |= f[i - 3];if(nums[i - 3] + 1 == nums[i - 2] && nums[i - 2] + 1 == nums[i - 1]) f[i] |= f[i - 3];}}return f[n];}
};

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

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

相关文章

推荐6款SSH远程连接工具

1、Xshell 介绍&#xff1a; xshell是一个非常强大的安全终端模拟软件&#xff0c;它支持SSH1, SSH2, 以及Windows平台的TELNET 协议。Xshell可以在Windows界面下用来访问远端不同系统下的服务器&#xff0c;从而比较好的达到远程控制终端的目的。 业界最强大的SSH客户机 官…

数据分析-Pandas数据的直方图探查

数据分析-Pandas数据的直方图探查 数据分析和处理中&#xff0c;难免会遇到各种数据&#xff0c;那么数据呈现怎样的规律呢&#xff1f;不管金融数据&#xff0c;风控数据&#xff0c;营销数据等等&#xff0c;莫不如此。如何通过图示展示数据的规律&#xff1f; 数据表&…

农产品质量追溯系统—功能介绍(2)

储藏管理 储藏信息管理对需要储藏的农产品,记录储藏的相关信息,如储藏开始时间、存放仓库、操作人员、储藏原因等; 仓库信息管理物流管理 物流公司管理对相关的物流公司信息进行登记,以便于管理和追溯; 车辆管理

我的秋招数据分析岗面经分享(京东,美团,阿里,拼多多,vivo,滴滴)

节前&#xff0c;我们社群组织了一场技术&面试讨论会&#xff0c;邀请了一些互联网大厂同学、参加社招和校招面试的同学&#xff0c;针对新手如何入门数据分析、机器学习算法、该如何备战面试、面试常考点分享等热门话题进行了深入的讨论。 基于社群的讨论&#xff0c;今天…

力扣爆刷第84天之hot100五连刷6-10

力扣爆刷第84天之hot100五连刷6-10 文章目录 力扣爆刷第84天之hot100五连刷6-10一、15. 三数之和二、42. 接雨水三、3. 无重复字符的最长子串四、438. 找到字符串中所有字母异位词五、560. 和为 K 的子数组 一、15. 三数之和 题目链接&#xff1a;https://leetcode.cn/problem…

JAVA学习笔记13(位运算)

1.位运算 1.1 原码、反码、补码 ​ *规则&#xff1a; ​ 1.二进制的最高位是符号位&#xff1a;0表示正数&#xff0c;1表示负数 ​ 2.正数的原码&#xff0c;反码&#xff0c;补码都一样&#xff08;三码合一&#xff09; ​ 3.负数的反码 他的原码符号位不变&#xff…

从metashape导出深度图,从深度图恢复密集点云

从metashape导出深度图&#xff0c;从深度图恢复密集点云 1.从metashape导出深度图 参考&#xff1a;https://blog.csdn.net/WHU_StudentZhong/article/details/123107072?spm1001.2014.3001.5502 2.从深度图建立密集点云 首先从metashape导出blockExchange格式的xml文件&…

OpenHarmony、HarmonyOS打开编辑 PDF 等操作的三方组件使用教程

项目场景: 随着数字化时代的发展,PDF 文档成为广泛应用于各行业的重要文件格式。为了提高OpenHarmony/HarmonyOS生态系统的功能性和用户体验,我们需要一款支持打开、编辑PDF文件的应用程序。 使用户能够轻松打开、浏览和编辑PDF文件。该应用将充分利用OpenHarmony/HarmonyO…

【NTN 卫星通信】卫星和无人机配合的应用场景

1 场景概述 卫星接入网是一种有潜力的技术&#xff0c;可以为地面覆盖差地区的用户提供无处不在的网络服务。然而&#xff0c;卫星覆盖范围对于位于考古或采矿地点内部/被茂密森林覆盖的村庄/山谷/靠近山丘或大型建筑物的用户可能很稀疏。因此&#xff0c;涉及卫星接入和无人驾…

HarmonyOS Full SDK的安装

OpenHarmony的应用开发工具HUAWEI DevEco Studio现在随着OpenHarmony版本发布而发布,只能在版本发布说明中下载,例如最新版本的OpenHarmony 4.0 Release。对应的需要下载DevEco Studio 4.0 Release,如下图。 图片 下载Full SDK主要有两种方式,一种是通过DevEco Studio下载…

教你用Fiddler捕获HTTPS请求

安装Fiddler 这里不特别说明了&#xff0c;网上搜索一大把&#xff0c;根据安装引导一步步安装即可。&#xff08;这里采用的是fiddler v4.6&#xff09; 配置Fiddler 1、打开fiddler配置Tools –>Telerik Fiddler Options。 2、打开HTTPS配置项&#xff0c;勾选“Captur…

【程序员养生延寿系列-万人关注的养生指南 4 】

1.早起一杯温水&#xff0c;疏通肠胃&#xff0c;补充水分。 2.早十点和下午三点左右活动活动身体&#xff08;运动or健身&#xff09;&#xff0c;放松紧张疲惫的身体&#xff0c;帮助消化&#xff0c;给身体透个气。 3.每天散步&#xff0c;好处多多&#xff08;减肥健身&a…

ctf_show笔记篇(web入门---爆破)

爆破 21&#xff1a;直接bp抓包跑字典&#xff0c;需base64加密 22&#xff1a;可用工具跑也可用浏览器找还可以用网上做好的域名查找去找 23&#xff1a;此题需跑脚本已经附上自写脚本 最后跑出来六个答案一个一个尝试得到答案为3j import hashlibm "0123456789qwert…

C++_AVL树

目录 1、AVL的概念 2、平衡因子的调整概念 3、AVL树的插入 3.1 调整平衡因子代码实现 3.2 右旋操作 3.2 左旋操作 3.3 双旋-先右旋再左旋 3.4 双旋-先左旋再右旋 3.5 旋转操作的小结 4、AVL的验证与实现 结语 前言&#xff1a; 在C中&#xff0c;AVL树是在二叉搜索…

2024中国眼博会,山东省眼科医学技术交流大会

以展带会&#xff0c;以会促展&#xff0c;展与会有机结合&#xff0c;立足山东打造具全国影响力的眼康产业发展盛会&#xff1b; ——随着时代的高速发展&#xff0c;科技的进步&#xff0c;现代生活节奏的加快&#xff0c;青少年近视问题日益严重&#xff0c;对儿童青少年的…

旧的Spring Security OAuth已停止维护,全面拥抱新解决方案Spring SAS

Spring Authorization Server 替换 Shiro 指引 背景 Spring 团队正式宣布 Spring Security OAuth 停止维护&#xff0c;该项目将不会再进行任何的迭代 目前 Spring 生态中的 OAuth2 授权服务器是 Spring Authorization Server 已经可以正式生产使用作为 SpringBoot 3.0 的最新…

如何使用naive 做一个模态框的方式

1.我的问题使用了一个table 表格&#xff0c;在表格中设置俩个按钮 最后做出来的效果 <template><div><h1>测试文件</h1><!-- 表格 --><n-data-table :columns"columns" :data"data" :pagination"pagination" …

Linux内核队列queue.h

文章目录 一、简介二、SLIST单向无尾链表2.1 介绍2.2 操作2.3 例子 三、STAILQ单向有尾链表四、LIST双向无尾链表五、TAILQ双向有尾链表六、CIRCLEQ循环链表七、queue源码参考 一、简介 queue.h是一个非常经典的文件&#xff0c;定义了一系列宏的操作&#xff0c;它定义了一系…

笔记72:关于IMU(惯性测量单元)传感器的作用【不涉及公式推导】

一、IMU传感器是什么&#xff1a; 惯性测量单元IMU&#xff08;Inertial Measurement Unit&#xff09;是一种使用【加速度计】和【陀螺仪】来测量【物体三轴姿态角&#xff08;空间姿态&#xff09;】的装置&#xff1b;IMU在坐标系的每个坐标轴上&#xff0c;均安装有1个陀螺…

90-子集2(回溯算法)

题目 给你一个整数数组 nums &#xff0c;其中可能包含重复元素&#xff0c;请你返回该数组所有可能的子集&#xff08;幂集&#xff09;。 解集 不能 包含重复的子集。返回的解集中&#xff0c;子集可以按 任意顺序 排列。 示例 1&#xff1a; 输入&#xff1a;nums [1,2,2] …