news 2026/4/15 9:11:56

hot100 128.最长连续序列

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
hot100 128.最长连续序列

思路:

1.题目要求时间复杂度为O(n),而排序的时间复杂度是O(nlogn),因此本题不能排序。

2.核心思路:对于nums中的元素x,以x为起点,不断查找下一个数x + 1,x + 2,...是否在nums中,并统计序列的长度。

3.为了做到O(n)的时间复杂度,需要做到两个关键优化。

(1)把nums中的数都放到一个哈希集合中,这样可以以O(1)的时间复杂度判断数字是否在nums中。

(2)如果x - 1在哈希集合中,则不以x为起点。这是因为以x - 1为起点计算出的序列长度,一定要比以x为起点计算出的序列长度要长,这样可以避免大量重复计算。比如nums == [3,2,4,5],从3开始,可以找到3,4,5这个连续序列;而从2开始,则可以找到2,3,4,5这个连续序列,一定比从3开始找到的连续序列要长。

4.注意:遍历元素的时候,要遍历哈希集合,而不是nums。如果nums =[1,1,1,...,1,2,3,4,5,...](前一半都是1),遍历nums的做法会导致每个1都跑一个O(n)的循环,总的循环次数是O(n^2),会超时。

附代码:

class Solution { public int longestConsecutive(int[] nums) { Set<Integer> set = new HashSet<>(); for(int num : nums){ set.add(num); //把nums转换成哈希集合 } int ans = 0; for(int x : set){ //遍历哈希集合 if(set.contains(x - 1)){ //如果x不是序列的起点,则直接跳过 continue; } //x是序列的起点 int y = x + 1; while(set.contains(y)){ //不断查找下一个数是否在哈希集合中 y++; } // 循环结束后,y - 1就是最后一个在哈希集合中的数 // 长度为 y - 1 - x + 1 = y - x ans = Math.max(ans,y - x); } return ans; } }

小优化:设m为nums中不同元素的个数(即哈希集合的大小)。各个连续序列(链)是相互独立的,如果发现其中一条链的长度至少为m/2(长度×2>=m),由于不可能还有一条长度大于m/2的链(否则这两条链的长度之和就超过m了),答案不会再增大,此时可以直接返回答案。

class Solution { public int longestConsecutive(int[] nums) { Set<Integer> set = new HashSet<>(); for(int num : nums){ set.add(num); //把nums转换成哈希集合 } int m = set.size(); int ans = 0; for(int x : set){ //遍历哈希集合 if(set.contains(x - 1)){ //如果x不是序列的起点,则直接跳过 continue; } //x是序列的起点 int y = x + 1; while(set.contains(y)){ //不断查找下一个数是否在哈希集合中 y++; } // 循环结束后,y - 1就是最后一个在哈希集合中的数 // 长度为 y - 1 - x + 1 = y - x ans = Math.max(ans,y - x); if(ans * 2 >= m){ break; } } return ans; } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/8 20:29:04

收藏必读!大模型行业应用全攻略:从通用到垂直的技术落地指南

行业大模型是弥合通用大模型与行业需求差距的产物&#xff0c;具有高性价比、专业定制和数据安全可控等优势。不同行业应用处于不同阶段&#xff0c;产业链两端进展较快。评估应避免将技术指标作为唯一标准&#xff0c;关注业务、技术指标相对提升。技术实现方式包括提示工程、…

作者头像 李华
网站建设 2026/4/7 23:13:20

性能测试实战宝典:从问题定位到优化的一站式解决方案

性能测试实战宝典&#xff1a;从问题定位到优化的一站式解决方案 掌握科学性能测试方法&#xff0c;让系统瓶颈无处遁形 一、性能测试的常见问题及定位方法内存溢出问题 内存溢出是性能测试中最常见的问题之一&#xff0c;主要包括堆内存溢出、栈内存溢出和永久代/方法区溢出。…

作者头像 李华
网站建设 2026/4/13 16:16:45

部署Qwen3-VL-30B显存需求全解析

Qwen3-VL-30B 显存需求全解析&#xff1a;从参数到生产落地的完整指南 &#x1f680; 你有没有试过满怀期待地把 Qwen3-VL-30B 加载进本地环境&#xff0c;结果刚一启动就弹出 OOM&#xff08;Out of Memory&#xff09;&#xff1f; 看着“激活参数仅 30B”的宣传语&#xff0…

作者头像 李华
网站建设 2026/4/14 19:45:30

无需API也能对话PDF:Anything-LLM开箱即用的文档助手体验

无需API也能对话PDF&#xff1a;Anything-LLM开箱即用的文档助手体验 在办公室里&#xff0c;一位法务人员正面对一份长达80页的合同草案&#xff0c;眉头紧锁。他不想逐字阅读&#xff0c;只关心“有哪些违约责任条款”“保密期限是多久”。过去&#xff0c;这需要几个小时的人…

作者头像 李华