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/

相关推荐
pao__pao_11 分钟前
计算机系统大作业 程序人生-Hello’s P2P
程序人生·职场和发展·课程设计
munubak11 分钟前
程序人生-Hello’s P2P
程序人生·职场和发展
努力学算法的蒟蒻15 分钟前
day109(3.10)——leetcode面试经典150
面试·职场和发展
芝士爱知识a17 分钟前
【程序人生】码农考公指南:是“降维打击”还是“围城自困”?
程序人生·职场和发展·程序员·公务员·考公·职场规划
炒鸡菜66618 分钟前
程序人生-Hello’s P2P
c语言·程序人生·职场和发展
weixin_4588726128 分钟前
东华复试OJ二刷复盘2
算法
Charlie_lll29 分钟前
力扣解题-637. 二叉树的层平均值
算法·leetcode
爱淋雨的男人38 分钟前
自动驾驶感知相关算法
人工智能·算法·自动驾驶
wen__xvn1 小时前
模拟题刷题3
java·数据结构·算法
滴滴答滴答答1 小时前
机考刷题之 6 LeetCode 169 多数元素
算法·leetcode·职场和发展