力扣128.最长连续序列

给定一个未排序的整数数组 nums ,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度。

请你设计并实现时间复杂度为 O(n) 的算法解决此问题。

python 复制代码
class Solution(object):
    def longestConsecutive(nums):
        num_set = set(nums)  # 先去重
        dp = {}
        max_len = 0

        def dfs(num):
            if num not in num_set:
                return 0
            if num in dp:     # 记忆化,避免重复算
                return dp[num]
            
            # 核心 DP:当前长度 = 1 + 下一个数的长度
            res = 1 + dfs(num + 1)
            dp[num] = res
            return res

        # 遍历每个数字,计算以它开头的长度
        for num in num_set:
            #得到以num开头的连续序列长度
            current_len = dfs(num)
            #更新最大连续序列长度
            max_len = max(max_len, current_len)
        return max_len     

思路:

1.先去重,使用set

2.使用动态规划,我们的dp定义是以num为开头的最长连续序列长度,

在递归函数里面,先判断num是否存在,如果不存在,说明num就不会是开头点,可以直接返回0,如果以num为开头的序列存在,就可以直接返回,如果还没定义,以num为开头的序列长度=以num+1为开头的序列长度+1

相关推荐
写代码写到手抽筋5 小时前
5G上行DCI字段判定:端口 流数 PMI选择详解
java·算法·5g
xieliyu.5 小时前
Java算法精讲:双指针(二)
java·开发语言·算法
wayz116 小时前
Momentum:PSL(心理线指标)技术指标详解
算法·金融·数据分析·量化交易·特征工程
8Qi87 小时前
LeetCode 213:打家劫舍 II(House Robber II)—— 题解 ✅
算法·leetcode·职场和发展·动态规划
三品吉他手会点灯7 小时前
C语言学习笔记 - 44.运算符和表达式 - 运算符2 - 除法与取余运算符
c语言·开发语言·笔记·算法
乐迪信息7 小时前
乐迪信息:AI算法盒子实时识别船舶烟雾与火焰异常
大数据·人工智能·算法·安全·目标跟踪
J-Tony117 小时前
【JVM】根可达算法
jvm·算法
艾iYYY7 小时前
string 类的模拟实现
android·服务器·c语言·c++·算法
Lsk_Smion8 小时前
力扣实训 _ [75].颜色分类 _ 杨辉三角
数据结构·算法·leetcode