哈希表法快速求解最长连续序列 | 力扣128题详细解析

❤️❤️❤️ 欢迎来到我的博客。希望您能在这里找到既有价值又有趣的内容,和我一起探索、学习和成长。欢迎评论区畅所欲言、享受知识的乐趣!

  • 推荐:数据分析螺丝钉的首页 格物致知 终身学习 期待您的关注
    在这里插入图片描述

  • 导航

    • LeetCode解锁1000题: 打怪升级之旅:每题都包括3-5种算法,以及详细的代码实现,刷题面试跳槽必备
    • 漫画版算法详解:通过漫画的形式和动态GIF图片把复杂的算法每一步进行详细可视解读,看一遍就掌握
    • python源码解读:解读python的源代码与调用关系,快速提升代码质量
    • python数据分析可视化:企业实战案例:企业级数据分析案例与可视化,提升数据分析思维和可视化能力
    • 程序员必备的数学知识与应用:全面详细的介绍了工程师都必备的数学知识

期待与您一起探索技术、持续学习、一步步打怪升级 欢迎订阅本专栏❤️❤️

题目描述

给定一个未排序的整数数组 nums,找出数字连续的最长序列的长度。要求时间复杂度在 O(n) 内。

注意:

  • 这个序列不需要在原数组中是连续的。

示例:

输入: [100, 4, 200, 1, 3, 2]
输出: 4
解释: 最长连续序列是 [1, 2, 3, 4]。它的长度是 4。

方法一:哈希表

解题步骤

  1. 使用哈希表存储所有数字,以便快速查找数组中的任意数字是否存在。
  2. 遍历数组 nums,对每个元素进行检查:
    • 如果其前一个元素 (num - 1) 不在哈希表中,则这是一个新序列的起点。
  3. 从起点开始,递增查找连续的数字,同时更新最长连续序列的长度。
  4. 返回找到的最大长度。

Python 示例

def longestConsecutive(nums):num_set = set(nums)max_length = 0for num in num_set:if num - 1 not in num_set:current_num = numcurrent_length = 1while current_num + 1 in num_set:current_num += 1current_length += 1max_length = max(max_length, current_length)return max_length# 示例使用
nums = [100, 4, 200, 1, 3, 2]
print(longestConsecutive(nums))  # 输出: 4

算法分析

  • 时间复杂度:O(n)。尽管看起来有双层循环,但每个数字在内层循环中只访问一次。
  • 空间复杂度:O(n),因为需要存储数组元素的哈希表。

详细步骤说明

  1. 构建哈希表

    • 将所有数字插入哈希表,确保每个数字能被快速查找。
    • 例如,对于输入 [100, 4, 200, 1, 3, 2],哈希表为 {100, 4, 200, 1, 3, 2}
  2. 查找序列起点

    • 遍历哈希表中的每个数字,判断是否为序列的起点。
    • 一个数字是序列起点的条件是其前一个数字不在哈希表中。
    • 例如,1 是起点,因为 0 不在哈希表中。
  3. 构建序列

    • 从序列起点开始,逐步查找下一个连续数字,并计算序列长度。
    • 例如,从 1 开始,可以找到 234,最终序列长度为 4

更多示例

  1. 输入:[0, -1, 1, 2, 3]

    • 输出:5
    • 解释:最长连续序列是 [-1, 0, 1, 2, 3],长度为 5
  2. 输入:[10, 5, 12, 3, 55, 6, 11, 8, 7, 9]

    • 输出:6
    • 解释:最长连续序列是 [5, 6, 7, 8, 9, 10],长度为 6

图示与说明

考虑 nums = [100, 4, 200, 1, 3, 2]

  1. 构建哈希表

    • 哈希表:{100, 4, 200, 1, 3, 2}
  2. 查找序列起点

    初始数组: [100, 4, 200, 1, 3, 2]
    哈希表构建: {100, 4, 200, 1, 3, 2}从 '1' 开始,因为 '0' 不在集合中,序列可以从 '1' 开始向上构建:
    1 -> 2 -> 3 -> 4
    连续序列长度为 4,是此数组的最长连续序列。
    
  3. 详细步骤说明

步骤当前数字当前序列最长序列长度
初始[100, 4, 200, 1, 3, 2]
构建哈希表{100, 4, 200, 1, 3, 2}
步骤11[1]1
步骤21 -> 2[1, 2]2
步骤31 -> 2 -> 3[1, 2, 3]3
步骤41 -> 2 -> 3 -> 4[1, 2, 3, 4]4

🌹🌹如果觉得这篇文对你有帮助的话,记得一键三连关注、赞👍🏻、收藏是对作者最大的鼓励,非常感谢 ❥(^_-)

❤️❤️作者知识有限,如有错误,请各位大佬评论区批评指正,不胜感激❥(^_-)
在这里插入图片描述

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

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

相关文章

关于电源3(整流滤波电路)

整流滤波电路 框图 一共有四种整流电路 以下是自己参考别人的文章https://blog.csdn.net/zhuguanlin121/article/details/130653498?ops_request_misc%257B%2522request%255Fid%2522%253A%2522171582622316800215096518%2522%252C%2522scm%2522%253A%252220140713.130102334…

jenkins配置不同版本nodeJS,保姆级叫你配置

问题描述:公司jenkins被改了nodejs版本适配其他项目导致以前的项目构建失败,原因就是nodejs版本太高或太低导致,这里教大家不去更改服务器默认版本,当需要特殊版本直接在jenkins里配置即可。 过程 1、安装nodeJS插件 1.1点击管…

怎么把照片变小做头像?多种方法教你图片改尺寸

现在在社交媒体平台或者是社交软件上,我们经常会去更改头像来展示自己,但是有时候我们拍摄的照片太大无法直接用作头像,这时候就需要去修改图片尺寸,将图片改大小到合适的数值才能使用,那么如何快速的将图片改大小呢&a…

Ansys Mechanical|中远程点的Behavior该如何设置?

Remote point是ANSYS mechanical中的一种常见节点自由度耦合建模形式,在转动装配体中的连接转动副、或者在施加远端约束及远端载荷的时候,我们经常用到远端单元来耦合一个面或者一条线。例如销轴似的滚动摩擦连接,如果我们希望将两个物体通过…

小白git

克隆 :git clone 链接地址 如果没有.git文件的话:git init 切换分支:cd 目录 拉代码:git pull 查看你自己改了那些文件:git status 添加道本地暂存区:git add * 提交到远端:git commit …

吴恩达深度学习笔记:优化算法 (Optimization algorithms)2.9-2.10

目录 第二门课: 改善深层神经网络:超参数调试、正 则 化 以 及 优 化 (Improving Deep Neural Networks:Hyperparameter tuning, Regularization and Optimization)第二周:优化算法 (Optimization algorithms)2.9 学习率衰减(Learning rate decay) 第二门…

HP5V80、HP5V105、HP3V28电比例驱动柱塞泵放大器

HP5V80、HP5V105、HP3V28、HP3V45、HP3V60、HP3V80、HP3V125、HP3V140带电比例控制泵放大器,变排量泵的排量可通过由BEUEC比例放大器输出到比例电磁阀电流变化而进行调整,控制电流范围为300mA至800mA(24VDC)或600mA至1600mA(12VDC)。主要适合应用于工程机…

【联通官网及APP注册/登录安全分析报告】

前言 由于网站注册入口容易被黑客攻击,存在如下安全问题: 暴力破解密码,造成用户信息泄露短信盗刷的安全问题,影响业务及导致用户投诉带来经济损失,尤其是后付费客户,风险巨大,造成亏损无底洞 …

「AI模型瘦身术」——知识蒸馏技术综述

使用KD原因 遇到问题:从产业发展的角度来看工业化将逐渐过渡到智能化,边缘计算逐渐兴起预示着 AI 将逐渐与小型化智能化的设备深度融合,这也要求模型更加的便捷、高效、轻量以适应这些设备的部署。 解决方案:知识蒸馏技术 知识…

Logic Pro X for Mac v11.0.0激活版:专业音频制作软件

对于音乐创作者来说,一个稳定、高效的工作流程至关重要。Logic Pro X for Mac提供了一系列工作流程优化功能,让你能够更快捷、高效地完成音乐创作。从添加音轨、录制音频,到混音和编曲,每一个步骤都如丝般顺滑。同时,L…

Maven 依赖排查

先从项目去看显而易见,假如我们有一个项目,父工程中包含一些子工程,如下: 我们想看一下samples-account中的依赖关系,那么我们可以打开 samples-account的pom文件,查看其maven依赖关系图。 我们可以看到此项…

ARM 交叉编译搭建SSH

一、源码下载 zlib:zlib-1.3.1.tar.xz openssl:openssl-0.9.8d.tar.gz openssh:openssh-4.6p1.tar.gz 二、交叉编译 1、zlib 编译参考这里 2、openssl tar -xf openssl-0.9.8d.tar.gz ./Configure --prefix/opt/ssh/openssl os/compile…

2024年抖店保证金交多少?保证金常见问题解答,一文解决你所有疑惑

大家好,我是电商花花 新手如果想要开抖音小店,有一个大坑是必须要避开的。 就是我们店铺开通之后,我们一定要交保证金,如果不交,那就是0元开店。 很多新手听别人说做抖音小店可以0元开店,不用缴纳保证金就…

开箱机选型“避坑”指南:风险识别与应对策略一网打尽

在现代化生产线上,开箱机作为关键设备之一,其选型过程的成功与否直接关系到生产效率与成本控制。然而,在选型过程中,往往会面临诸多风险,如何有效识别并应对这些风险,成为企业关注的焦点。星派将为您详细解…

JETBRAINS IDES 分享一个2099通用试用码!DataGrip 2024 版 ,支持一键升级

文章目录 废话不多说上教程:(动画教程 图文教程)一、动画教程激活 与 升级(至最新版本) 二、图文教程 (推荐)Stage 1.下载安装 toolbox-app(全家桶管理工具)Stage 2 : 下…

百度Comate插件领50京东E卡

给你分享一个AI编码助手——百度Comate!扫码参与抽红包活动,520宠粉!送京东卡!https://url.xffjs.com/sMsP7m 流程如下 点击:点我传送 验证码登录账户 点击个人中心 复制License 去idea或者vscode安装插件 询问一…

【Redis】Redis 主从集群(二)

1.哨兵机制原理 1.1.三个定时任务 Sentinel 维护着三个定时任务以监测 Redis 节点及其它 Sentinel 节点的状态 1)info 任务:每个 Sentinel 节点每 10 秒就会向 Redis 集群中的每个节点发送 info 命令,以获得最新的 Redis 拓扑结构 2&#xff…

RabbitMQ的基本组件有哪些?

RabbitMQ的基本组件有哪些? RabbitMQ介绍、解耦、提速、削峰、分发 详解、RabbitMQ安装 可视化界面讲解 RabbitMQ 不生产消息,他是消息的搬运工。 1. Producer: 消息的发布者。 2. Connection:producer/comsumer 和 Message Broker 之间的 TCP 连接。 3…

JavaGUI---JavaFX---未完结

一、Java事件处理机制的应用 JavaFX:JavaFX是Java平台上的一个GUI工具包,它提供了一些内置的事件处理机制。 Swing:Swing是Java平台上的另一个GUI工具包,它也提供了一些内置的事件处理机制。 二、JavaFX和Swing的关键区别&…

20232906 2023-2024-2 《网络与系统攻防技术》第十次作业

20232906 2023-2024-2 《网络与系统攻防技术》第十次作业 1.实验内容 一、SEED SQL注入攻击与防御实验 我们已经创建了一个Web应用程序,并将其托管在http://www.seedlabsqlinjection.com/(仅在SEED Ubuntu中可访问)。该Web应用程序是一个简…