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/

相关推荐
budingxiaomoli3 分钟前
优选算法-多源bfs解决拓扑排序问题
算法·宽度优先
隔壁大炮4 分钟前
10.PyTorch_元素类型转换
人工智能·pytorch·深度学习·算法
The Chosen One9854 分钟前
算法题目分享(二分算法)
算法·职场和发展·蓝桥杯
玛丽莲茼蒿7 分钟前
Leetcode hot100 矩阵置零【中等】
算法·leetcode·矩阵
澈2078 分钟前
算法进阶:二叉树翻转与环形链表解析
数据结构·算法·排序算法
:1218 分钟前
java数组2
java·算法·排序算法
代码飞天8 分钟前
算法与数据结构之树——让数据查找更加迅速
数据结构·算法
贾斯汀玛尔斯10 分钟前
每天学一个算法--外部排序(External Sorting)
算法
故事和你9111 分钟前
洛谷-算法2-2-常见优化技巧1
开发语言·数据结构·c++·算法·动态规划·图论
酉鬼女又兒13 分钟前
JavaLeetCode 第一题「两数之和」:从暴力枚举到一遍哈希表的正确与错误实现,详解HashMap核心知识点及常见陷阱
java·开发语言·数据结构·算法·leetcode·职场和发展·散列表