news 2026/4/15 15:15:30

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
力扣hot100第三题:最长连续序列python

第一部分:题目要求

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

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/7 16:51:03

如何举报滥用Sonic生成的不当内容?渠道公布

如何识别与举报滥用Sonic生成的不当内容&#xff1f;技术解析与应对指南 在虚拟主播一夜涨粉百万、AI换脸视频频现热搜的今天&#xff0c;数字人技术正以前所未有的速度重塑内容生态。其中&#xff0c;由腾讯联合浙江大学研发的轻量级口型同步模型Sonic&#xff0c;因其仅需一…

作者头像 李华
网站建设 2026/4/15 14:36:03

Sonic数字人参加TED演讲?模拟舞台表现力

Sonic数字人参加TED演讲&#xff1f;模拟舞台表现力 在一场虚拟的TED讲台上&#xff0c;聚光灯缓缓亮起。镜头前&#xff0c;一位神情专注的演讲者正娓娓道来&#xff0c;唇形精准地随着语句跳动&#xff0c;眼神自然流转&#xff0c;偶尔微笑点头&#xff0c;仿佛真实站在观众…

作者头像 李华
网站建设 2026/4/14 8:33:27

基于SpringBoot的自主推荐房源信息系统的研发毕设

博主介绍&#xff1a;✌ 专注于Java,python,✌关注✌私信我✌具体的问题&#xff0c;我会尽力帮助你。一、研究目的本研究旨在研发一套基于SpringBoot框架的自主推荐房源信息系统&#xff0c;以满足现代房地产市场对个性化、智能化推荐服务的需求。具体研究目的如下&#xff1a…

作者头像 李华
网站建设 2026/4/12 16:58:57

Sonic数字人输出视频编码格式是H.264

Sonic数字人输出视频编码格式是H.264 在虚拟内容爆发式增长的今天&#xff0c;我们正见证一场由AI驱动的“数字人格革命”。从直播间里的虚拟主播&#xff0c;到企业宣传中的智能客服&#xff0c;再到教育课程中的卡通讲师——数字人不再只是科技展上的概念演示&#xff0c;而…

作者头像 李华
网站建设 2026/4/12 21:16:34

德语严谨发音对应嘴型?Sonic识别准确

德语严谨发音对应嘴型&#xff1f;Sonic识别准确 在虚拟主播24小时不间断带货、AI教师用多国语言讲解课程的今天&#xff0c;数字人早已不再是炫技的“科技花瓶”。真正决定用户体验的&#xff0c;不是华丽的3D建模&#xff0c;而是那一瞬间的“真实感”——当一个德语单词说出…

作者头像 李华
网站建设 2026/4/12 5:36:33

springboot基于web的可追溯果蔬生产过程的管理系统-vue

目录系统概述功能模块技术亮点应用价值项目技术支持论文大纲核心代码部分展示可定制开发之亮点部门介绍结论源码获取详细视频演示 &#xff1a;文章底部获取博主联系方式&#xff01;同行可合作系统概述 基于SpringBoot和Vue的可追溯果蔬生产管理系统旨在实现果蔬从种植到销售…

作者头像 李华