【Golang】LeetCode 128. 最长连续序列

128. 最长连续序列

题目描述

思路

题目要求我们以O(n)的时间复杂度解决当前问题,解决的具体手段就是使用哈希表。

首先我们创建一个类型为map[int]bool的哈希表,用于记录nums数组当中某个数是否出现过。

之后,我们开始对哈希表的key进行遍历,来寻找当前的key对应的可能的连续序列。

此处有一个小技巧,那就是如果key - 1这个数已经在map当中出现过了,我们就不再对key的连续序列进行查找了,原因是如果key - 1已经出现过,那么key一定已经在遍历key - 1寻找其连续序列时被遍历过了,我们不需要对其连续序列进行重复查找,因为此时找到的连续序列的长度已经没有以key - 1作为起点找到的连续序列要短。

如果key - 1不在map当中,我们开始对key进行遍历。我们令curr, currLen := num, 0,我们以mp[curr] == true作为条件进行遍历,并在每一次循环时令curr, currLen = curr + 1, currLen + 1,也就是每一次都寻找当前数加一的后面的那个数,如果它在哈希表当中,则增大当前连续序列的长度。

最后令ans = max(ans, currLen),最终返回ans就是我们想要的答案。

Golang 题解

go 复制代码
func longestConsecutive(nums []int) int {
    mp := map[int]bool{}
    for _, num := range nums {
        mp[num] = true
    }

    ans := 0
    for num := range mp {
        if mp[num - 1] != true {
            curr, currLen := num, 0
            for mp[curr] {
                curr ++
                currLen ++
            }
            ans = max(ans, currLen)
        }
    }

    return ans
}
相关推荐
月挽清风13 小时前
代码随想录第十五天
数据结构·算法·leetcode
TracyCoder12316 小时前
LeetCode Hot100(34/100)——98. 验证二叉搜索树
算法·leetcode
We་ct17 小时前
LeetCode 56. 合并区间:区间重叠问题的核心解法与代码解析
前端·算法·leetcode·typescript
努力学算法的蒟蒻20 小时前
day79(2.7)——leetcode面试经典150
算法·leetcode·职场和发展
2401_8414956420 小时前
【LeetCode刷题】二叉树的层序遍历
数据结构·python·算法·leetcode·二叉树··队列
2401_8414956420 小时前
【LeetCode刷题】二叉树的直径
数据结构·python·算法·leetcode·二叉树··递归
我是咸鱼不闲呀21 小时前
力扣Hot100系列19(Java)——[动态规划]总结(上)(爬楼梯,杨辉三角,打家劫舍,完全平方数,零钱兑换)
java·leetcode·动态规划
铉铉这波能秀21 小时前
LeetCode Hot100数据结构背景知识之列表(List)Python2026新版
数据结构·leetcode·list
仟濹1 天前
算法打卡 day1 (2026-02-06 周四) | 算法: DFS | 1_卡码网98 可达路径 | 2_力扣797_所有可能的路径
算法·leetcode·深度优先