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/

相关推荐
patrickpdx1 分钟前
leetcode:环形链表
算法·leetcode·链表
资深web全栈开发3 分钟前
LeetCode 3652: 按策略买卖股票的最佳时机
算法·leetcode·职场和发展
小徐Chao努力6 分钟前
【GO】Gin 框架从入门到精通完整教程
开发语言·golang·gin
Wang ruoxi12 分钟前
基于最小二乘法的离散数据拟合
人工智能·算法·机器学习
Xの哲學16 分钟前
Linux链路聚合深度解析: 从概念到内核实现
linux·服务器·算法·架构·边缘计算
加成BUFF22 分钟前
C++入门讲解3:数组与指针全面详解
开发语言·c++·算法·指针·数组
代码游侠31 分钟前
应用——管道与文件描述符
linux·服务器·c语言·学习·算法
一招定胜负33 分钟前
决策树开篇
算法·决策树·机器学习
GoWjw34 分钟前
C语言高级特性
c语言·开发语言·算法
carver w38 分钟前
说人话版 K-means 解析
算法·机器学习·kmeans