LeetCode讲解篇之128. 最长连续序列

文章目录

题目描述

题解思路

首先我们可以将所有数字保存在集合中,然后 最长连续序列的开头数字 - 1 一定不存在于数组中,想到这一点,这题就迎刃而解了

我们只需要遍历集合

如果遍历到的当前数字 - 1存在于数组中就跳过这个数字的处理

如果遍历到的当前数字 - 1不存在于数组中,找寻以当前数字开头的最长连续序列,然后与结果取最长值

最终遍历结果,返回最长的连续序列长度即可

题解代码

go 复制代码
func longestConsecutive(nums []int) int {
    m := map[int]struct{}{}
    for i := 0; i < len(nums); i++ {
        m[nums[i]] = struct{}{}
    }
    ans := 0
    for num := range m {
        if _, ok := m[num - 1]; ok {
            continue
        }
        offset := 0
        for {
            offset++
            _, ok := m[num + offset]
            if !ok {
                break
            }
        }

        ans = max(ans, offset)
    }

    return ans
}

题解链接

https://leetcode.cn/problems/longest-consecutive-sequence/

相关推荐
我是咸鱼不闲呀2 分钟前
力扣Hot100系列21(Java)——[多维动态规划]总结(不同路径,最小路径和,最长回文子串,最长公共子序列, 编辑距离)
java·leetcode·动态规划
lihao lihao5 分钟前
二分查找
java·数据结构·算法
WolfGang0073218 分钟前
代码随想录算法训练营 Day15 | 二叉树 part05
数据结构·算法
sheeta19988 分钟前
LeetCode 每日一题笔记 2025.03.20 3567.子矩阵的最小绝对差
笔记·leetcode·矩阵
代码栈上的思考8 分钟前
消息队列持久化:文件存储设计与实现全解析
java·前端·算法
软考通8 分钟前
2026年上半年软考报名时间更新,部分地区已截止报名!
职场和发展·职场发展·软考
qq_4176950518 分钟前
内存对齐与缓存友好设计
开发语言·c++·算法
2301_8166512219 分钟前
实时系统下的C++编程
开发语言·c++·算法
2401_8318249620 分钟前
C++与Python混合编程实战
开发语言·c++·算法