【算法】最长连续序列

题目:最长连续序列

给定一个未排序的整数数组 nums ,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度。

请你设计并实现时间复杂度为 O(n) 的算法解决此问题。

示例 1:
输入:nums = [100,4,200,1,3,2]
输出:4
解释:最长数字连续序列是 [1, 2, 3, 4]。它的长度为 4。

示例 2:
输入:nums = [0,3,7,2,5,8,4,6,0,1]
输出:9

提示:
0 <= nums.length <= 105
-109 <= nums[i] <= 109

我们做算法题的时候,一定先审好题:题目要求找出数字连续的最长序列(不要求序列元素在原数组中的连续)的长度。
其中的关键点是不要求在原数组的连续,所以我们可以进行先进行去重和排序

解题思路:

这道题的关键点在于如何识别并统计出最长的连续数字序列。我们可以采用以下步骤来解决问题:

  1. 去重与排序:首先,我们需要去除数组中的重复元素并对其进行排序。这是因为连续序列的元素在排序后会相邻,且去重可以避免重复计算同一个数字。(先用new Set去重,再用sort进行排序)
  2. 遍历排序后的数组:然后,遍历排序后的数组,逐个检查每个数字是否可以延伸出一个更长的连续序列,这里的关键思路是,从数组中的第二个值开始遍历,对于当前的数字,如果前一个数字与当前数字相差为1,说明是连续的。就把它加入到当前的连续序列中;否则,它就作为新序列的起始点。
  3. 记录最长序列长度:在遍历过程中,不断更新最长序列的长度。并在遍历结束后返回这个长度。

JavaScript实现:

/*** @param {number[]} nums* @return {number}*/
var longestConsecutive = function (nums) {// 先判断是否为一个空数组,如果是,就返回0if (nums.length === 0) return 0;// 先去重,再排序,然后得到一个每个数字具有唯一性的数组let uniqueNums = Array.from(new Set(nums)).sort((a, b) => a - b)// 接着声明最长数字连续序列长度为1,然后需要声明一个存储当前长度的变量,初始化值为1let maxLength = currentLength = 1;// 数组经过去重排序之后,接着进行遍历数组,如果数组当前值与前一个值相差为1,说明是连续的,当前长度加currentLength加1。// 如果不相等,则重新比较maxLength与currentLength值,最大的赋值给maxLength,currentLength则重新开始从1算起。for (let i = 1; i < uniqueNums.length; i++) {if (uniqueNums[i] === uniqueNums[i - 1] + 1) {currentLength++; // 如果数组当前值与前一个值相差为1,说明是连续的,当前长度加currentLength加1} else {// 如果不相等,则重新比较maxLength与currentLength值,最大的赋值给maxLength,currentLength则重新开始从1算起。maxLength = Math.max(maxLength, currentLength);currentLength = 1;}}// 最后再比较一下最大长度值和当前长度值,得出最后的最大长度。为什么最后再比较一下呢,// 因为在上面的循环中,只有在else中maxLength才会进行更新,如果是一直在if中,maxLength就不会进行更新,所以最后需要重新比较一下。maxLength = Math.max(maxLength, currentLength);return maxLength;
}

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

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

相关文章

使用LabVIEW报告生成工具包时报错97

问题详情&#xff1a; 在运行使用Excel/Word调用节点的程序时&#xff0c;收到错误97&#xff1a;LabVIEW&#xff1a;&#xff08;十六进制0x61&#xff09;输入中传递了一个空引用句柄或先前已删除的引用句柄。 当运行报告生成工具包中的一个示例程序时&#xff0c;收到错误…

速锐得解码汽车以太网技术特点接口定义数据传输及应用

在当前的汽车工业中&#xff0c;随着技术的飞速发展&#xff0c;车载网络技术也在不断进步与更新。其中&#xff0c;具备以太网的车型已成为一个新兴趋势&#xff0c;这主要归功于车载以太网技术在车内带宽需求较高的系统上的应用&#xff0c;如高级驾驶辅助系统&#xff08;AD…

1000T的文件怎么能快速从南京传到北京?最佳方案你肯定想不到

今天刷面试题看到一个有意思的面试题&#xff0c; 1000T的文件怎么能以最快速度从南京传到北京&#xff1f; 网络传输 首先我们考虑通过网络传输&#xff0c;需要多长时间。 我特地咨询了在运营商工作的同学&#xff0c;目前带宽&#xff1a; 家庭宽带下行最大1Gbps&#…

Python学习笔记27:进阶篇(十六)常见标准库使用之质量控制中的代码质量与风格第一部分

前言 本文是根据python官方教程中标准库模块的介绍&#xff0c;自己查询资料并整理&#xff0c;编写代码示例做出的学习笔记。 根据模块知识&#xff0c;一次讲解单个或者多个模块的内容。 教程链接&#xff1a;https://docs.python.org/zh-cn/3/tutorial/index.html 质量控制…

Linux应用---内存映射

写在前面&#xff1a; 在进程间通信中&#xff0c;有一种方式内存映射。内存映射也是进程间通信的方式之一&#xff0c;其效率高&#xff0c;可以直接对内存进行操作。本节我们对内存映射进行学习&#xff0c;并结合案例进行实践。 1、基本理论 内存映射&#xff1a;是将磁盘文…

代码随想录-Day46

121. 买卖股票的最佳时机 给定一个数组 prices &#xff0c;它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。 你只能选择 某一天 买入这只股票&#xff0c;并选择在 未来的某一个不同的日子 卖出该股票。设计一个算法来计算你所能获取的最大利润。 返回你可以从…

【JVM-05】Java内存区域(运行时数据区)、对象创建过程、内存布局

【JVM-05】Java内存区域即运行时数据区、对象创建过程、内存布局 1. 介绍下Java内存区域(运行时数据区)1.1 程序计数器(线程私有)1.2 虚拟机栈(线程私有)1.3 本地方法栈(线程私有)1.4 Java堆(线程共享)1.5 方法区(线程共享)1.5.1 方法区和永久代的关系1.5.2 常用参数1.5.3 为什…

Halcon支持向量机

一 支持向量机 1 支持向量机介绍&#xff1a; 支持向量机(Support Vector Machine&#xff0c;SVM)是Corinna Cortes和Vapnik于1995年首先提出的&#xff0c;它在解决小样本、非线性及高维模式识别表现出许多特有的优势。 2 支持向量机原理: 在n维空间中找到一个分类超平面…

node与npm安装教程

node与npm的下载安装教程&#xff1a; 文章目录 node与npm的下载安装教程&#xff1a;---Node.js 介绍NPM 介绍 一&#xff1a;下载&#xff08;node与npm的安装包是在一起的&#xff09;二&#xff1a;安装1&#xff1a;双击运行安装文件1-node-v14.15.0-x64.msi,点击下一步。…

前端uni-app篇之在uni-app中实现图片瀑布流布局并进行性能优化

在uni-app中实现图片瀑布流布局并进行性能优化。 考虑从以下几个方面优化&#xff1a; 使用虚拟列表&#xff1a;对于大量图片的加载&#xff0c;可以使用虚拟列表技术&#xff0c;只渲染屏幕可见的图片&#xff0c;未进入视口的图片不加载&#xff0c;从而减少内存占用和提高…

常用渲染管线介绍

1、光栅化渲染管线&#xff08;Raster pipeline&#xff09; 1.1、光栅化概述 光栅化图形渲染管线是实时渲染的核心组件。渲染管线的功能是通过给定虚拟相机、3D场景物体以及光源等场景要素来产生或者渲染一副2D的图像。如上图所示&#xff0c;场景中的3D物体通过管线转变为屏…

动态渲染dom

最近在做类似论文生成的一个系统&#xff0c;比较复杂&#xff0c;简单来说就是文字、图表的展示&#xff0c;但是顺序不固定&#xff0c;所以有动态渲染dom的需求&#xff0c;以下是我写的小demo&#xff0c;以作记录。 <template><div id"app"><div…

第一周java.1

一维数组 java数组要求所有数组元素具有相同的数据型。因此&#xff0c;在一个数组中&#xff0c;数组元素的类型是唯一的&#xff0c;即一个数组里只能存储一种数据类型的数据&#xff0c;而不能存储多种数据类型的数据 。 一旦数组的初始化完成 &#xff0c;数组在内存中所…

自媒体的竞争将会何去何从?

未来自媒体的竞争将会呈现出以下几个主要的发展趋势&#xff1a; 1. 内容质量与垂直化竞争加剧 内容质量提升&#xff1a;在信息爆炸的时代&#xff0c;用户对优质内容的需求越来越高。自媒体创作者需要不断提升自己的专业素养和创作能力&#xff0c;以提供有深度、有价值的内…

Datadog Dash 2024 新功能解析

Datadog 2024 年的 Dash 刚刚落下帷幕&#xff0c;作为正在与 Datadog 开始竞争的观测云&#xff0c;我们认真仔细的分析了 Datadog 的每一个新功能&#xff0c;发现一些很有意思的事情&#xff0c;今天就给大家做一次全面的分析。&#xff08;所有 Datadog 的 Dash 的最新功能…

基于改进YOLOv5s的跌倒行为检测 | 引入SKAttention注意机制 + 引入空间金字塔池化结构SPPFCSPC + 结合ASFF自适应空间融合

前言&#xff1a;Hello大家好&#xff0c;我是小哥谈。为了实现电厂人员跌倒行为的实时检测&#xff0c;防止跌倒昏迷而无法及时发现并救援的事件发生&#xff0c;针对跌倒行为检测实时性以及特征提取能力不足的问题&#xff0c;提出了一种改进YOLOv5s的跌倒行为检测算法网络&a…

PD虚拟机和VirtualBox有什么区别?Parallels Desktop 19.1.1 破解版

随着计算机技术的不断发展&#xff0c;虚拟机软件在现代信息技术领域中扮演着越来越重要的角色。虚拟机不仅可以帮助用户在一台物理机器上运行多个操作系统&#xff0c;还能有效隔离不同环境&#xff0c;提升系统安全性。在众多的虚拟机软件中&#xff0c;PD虚拟机&#xff08;…

第一百三十八节 Java数据类型教程 - Java boolean数据类型和float数据类型

Java数据类型教程 - Java boolean数据类型 布尔数据类型只有两个有效值:true和false。 这两个值称为布尔值字面量。 我们可以使用布尔值字面量 boolean done; // Declares a boolean variable named done done true; // Assigns true to done布尔变量不能转换为任何其他…

Unity按键表大全

Unity键值对应表# KeyCode是由Event.keyCode返回的。这些直接映射到键盘上的物理键&#xff0c;以下是键值对应列表&#xff1a; 常用键# Backspace 退格键 Delete Delete键 TabTab键 Clear Clear键 Return 回车键 Pause 暂停键 Escape ESC键 Space 空格键 小键盘# …

ESP32-VScode环境设置

目录 前言 一、安装VSCode 二、安装ESP32环境 1.安装ESP-IDF 2.ESP-IDF设置 3:开始配置环境 4.打开example进行验证 5.烧录 6.调整波特率 总结 前言 环境&#xff1a;Visual Studio Code 芯片&#xff1a;ESP32 说实话&#xff0c;这是我装的时间最长的一个环境&…