(哈希)128. 最长连续序列

题目

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

思路

在LeetCode上,选择使用哈希实现,为什么要使用这种方式?

  • 可能是使用这种方式去获取值比较快
  • 排序的算法复杂度相对比较高
  • 时间复杂度要求是O(n),如果使用排序时间复杂度最少nlogn

题解的关键是找开头,即确定是不是开头的数字

  • 如果是开头的话,往后遍历值+1,while循环(值包含则继续这个循环)

  • 否则,继续向后遍历找开头

  • 找开头?如果集合中不包含当前这个num-1,便说明不是开头

  • 需要将重复数字过滤set

示例:题解中的序列举例: 100,4,200,1,3,4,2

去重后的哈希序列为:100,4,200,1,3,2

  1. 元素100是开头,因为没有99,且以100开头的序列长度为1
  2. 元素4不是开头,因为有3存在,过,
  3. 元素200是开头,因为没有199,且以200开头的序列长度为1
  4. 元素1是开头,因为没有0,且以1开头的序列长度为4,因为依次累加,2,3,4都存在。
  5. 元素3不是开头,因为2存在,过,
  6. 元素2不是开头,因为1存在,过。
  7. 结束

算法

java 复制代码
class Solution {
    public int longestConsecutive(int[] nums) {
        Set<Integer> num_set = new HashSet<Integer>();
        for (int num : nums) {
            num_set.add(num);
        }

        int longestStreak = 0;

        for (int num : num_set) {
            // 找开头
            if (!num_set.contains(num - 1)) {
                int currentNum = num;
                int currentStreak = 1;
				// 向后遍历是否有连续数字
                while (num_set.contains(currentNum + 1)) {
                    currentNum += 1;
                    currentStreak += 1;
                }

                longestStreak = Math.max(longestStreak, currentStreak);
            }
        }

        return longestStreak;
    }
}
相关推荐
运筹vivo@14 小时前
LeetCode 2574. 左右元素和的差值
算法·leetcode·职场和发展·每日一题
计算机安禾14 小时前
【数据库系统原理】第4篇:关系数据结构的形式化定义:域、笛卡尔积与关系模式
数据结构·数据库·算法
手写码匠14 小时前
手写 DeepSeek 推理引擎优化:从 FP16 到 INT4 的量化加速实战
人工智能·深度学习·算法·aigc
GuWenyue14 小时前
LeetCode 76 最小覆盖子串|JS 滑动窗口标准解法
前端·算法·面试
一只齐刘海的猫15 小时前
【Leetcode】移动零
算法·leetcode·职场和发展
人道领域15 小时前
【LeetCode刷题日记】131.分割回文串,动态规划优化
java·开发语言·leetcode
落羽的落羽16 小时前
【项目】JsonRpc框架——开发实现1(细节功能、字段定义、抽象层、具象层)
linux·服务器·网络·c++·人工智能·算法·机器学习
handler0116 小时前
【算法】并查集(普通/扩展/带权)模板与例题
数据结构·c++·笔记·算法·c·图论·查并集
qq74223498416 小时前
从“感知”到“决断”:测评百度伐谋产业决策智能体的端到端推理与行动机制
人工智能·算法·百度·大模型·运筹优化
huohaiyu17 小时前
深入解析Java垃圾回收机制
java·开发语言·算法·gc