尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

力扣hot100第三题:最长连续序列python

力扣hot100第三题:最长连续序列python
📅 发布时间:2026/6/19 17:57:52

第一部分:题目要求

给定一个未排序的整数数组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

示例 3:

输入:nums = [1,0,1,2]输出:3

提示:

  • 0 <= nums.length <= 105
  • -109 <= nums[i] <= 109

第二部分:代码实现

(1)去重(利用集合特性)

#第一步:去重 nums_set=set(nums)
  • 核心操作:nums_set = set(nums)
  • 作用:将原始列表nums转换为集合(set),利用集合「元素唯一性」的特性,自动剔除列表中的重复整数,避免重复元素对后续连续序列判断造成干扰(比如若列表有重复的2,去重后仅保留一个,不影响连续序列长度计算)。

(2)重新排序(从小到大)

#第二步:重新排序(从小到大) nums_set_sort=sorted(nums_set)
  • 核心操作:nums_set_sort = sorted(nums_set)
  • 作用:使用sorted()函数对去重后的集合进行升序排序,得到一个有序的列表。只有将元素按从小到大排列,才能方便后续依次判断相邻元素是否为连续整数(即后一个元素是否等于前一个元素 + 1)。

(3)计数(统计最长连续整数序列长度)

#第三步:计数 max_count = 1 now_count=1#考虑到有多组连续数,需要比较大小 if len(nums_set_sort)==0: print(0) else: now=nums_set_sort[0] for i in range(1,len(nums_set_sort)): if nums_set_sort[i]==now+1:# 代表连续 now_count+=1 now=nums_set_sort[i] else: if(now_count>=max_count): max_count=now_count now_count=1#重置 now=nums_set_sort[i] if (now_count >= max_count):#确保max_count(如果给的是连续的12345,那么到5的时候,now_count=5,max_count=1,没有机会走上面的那个else分支) max_count = now_count print(max_count)
  • 核心操作:通过循环遍历有序列表,对比相邻元素,维护两个计数变量(max_count、now_count)完成统计。
  • 作用:这是核心业务逻辑步骤,负责计算最长连续整数序列的长度,具体细分 3 个小逻辑:
    1. 变量初始化:max_count(记录全局最长长度,初始为 1,因为至少有 1 个元素)、now_count(记录当前连续序列长度,初始为 1)、now(记录当前基准元素,初始为有序列表第一个元素);
    2. 循环判断:从列表第二个元素开始遍历,若当前元素等于「基准元素 + 1」,说明连续,当前计数now_count加 1,并更新基准元素;若不连续,就用当前计数更新全局最长计数,再重置当前计数和基准元素;
    3. 边界兜底:额外添加一次now_count >= max_count的判断,避免出现「列表末尾是最长连续序列」(无法进入else分支更新max_count)的情况,保证统计结果准确。

(4)完整提交代码

class Solution: def longestConsecutive(self, nums: List[int]) -> int: #第一步:去重 nums_set=set(nums) #第二步:重新排序(从小到大) nums_set_sort=sorted(nums_set) #第三步:计数 max_count = 1 now_count=1#考虑到有多组连续数,需要比较大小 if len(nums_set_sort)==0: return 0 else: now=nums_set_sort[0] for i in range(1,len(nums_set_sort)): if nums_set_sort[i]==now+1:# 代表连续 now_count+=1 now=nums_set_sort[i] else: if(now_count>=max_count): max_count=now_count now_count=1#重置 now=nums_set_sort[i] if (now_count >= max_count):#确保max_count(如果给的是连续的12345,那么到5的时候,now_count=5,max_count=1,没有机会走上面的那个else分支) max_count = now_count return max_count

(5)pycharm版本

nums = [100,4,200,1,3,2] #第一步:去重 nums_set=set(nums) #第二步:重新排序(从小到大) nums_set_sort=sorted(nums_set) #第三步:计数 max_count = 1 now_count=1#考虑到有多组连续数,需要比较大小 if len(nums_set_sort)==0: print(0) else: now=nums_set_sort[0] for i in range(1,len(nums_set_sort)): if nums_set_sort[i]==now+1:# 代表连续 now_count+=1 now=nums_set_sort[i] else: if(now_count>=max_count): max_count=now_count now_count=1#重置 now=nums_set_sort[i] if (now_count >= max_count):#确保max_count(如果给的是连续的12345,那么到5的时候,now_count=5,max_count=1,没有机会走上面的那个else分支) max_count = now_count print(max_count)

相关新闻

  • 基于SpringBoot的智慧社区服务平台的设计与实现毕业设计
  • AI排名优化兴起:企业如何提升人工智能生态中的可见度
  • 从“插件化”到“AI-Ready”:整洁架构在智能体系统中的实战升级

最新新闻

  • 常州多年黄金回收攻略,三十年实体经营,收的顶本地口碑有保障 - 奢侈品回收测评
  • 01_系统架构设计
  • 如何免费实现专业级直播抠像:obs-backgroundremoval插件完全指南
  • 新手必看!抖音保存视频到相册的详细步骤技巧 - 工具软件使用方法推荐
  • LaTeX长表格排版进阶:如何用longtable宏包实现跨页表格的精细控制?
  • 2026亲测:专业降AIGC软件选它准没错 - 降AI小能手

日新闻

  • 5分钟掌握Python进化算法:Geatpy高性能优化工具完全指南
  • Microchip 24AA044 EEPROM选型与应用全指南:从参数解析到实战编程
  • 华为的鸿蒙到底有多牛?为什么称作遥遥领先?

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号