最长连续序列

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

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

示例 1:

复制代码
输入:nums = [100,4,200,1,3,2]
输出:4
解释:最长数字连续序列是 [1, 2, 3, 4]。它的长度为 4。

示例 2:

复制代码
输入:nums = [0,3,7,2,5,8,4,6,0,1]
输出:9

示例 3:

复制代码
输入:nums = [1,0,1,2]
输出:3

提示:

  • 0 <= nums.length <= 105
  • -109 <= nums[i] <= 109
java 复制代码
class Solution {
    public int longestConsecutive(int[] nums) {
        Arrays.sort(nums);
        int oldResult = 0;
        int result = 0;
        for (int i = 0; i < nums.length; i++) {
            if (i == 0 || nums[i] == nums[i - 1] + 1) {
                result++;
            } else if (nums[i] > nums[i - 1] + 1) {
                if (result > oldResult) {
                    oldResult = result;
                }
                result = 1;
            }
        }
        return oldResult > result ? oldResult : result;
    }
}
相关推荐
Jia ming6 小时前
C语言实现日期天数计算
c语言·开发语言·算法
阿维的博客日记6 小时前
为什么会增加TreeMap和TreeSet这两类,有什么核心优势吗?可以解决什么核心痛点?
java·treeset·treemap
dllxhcjla6 小时前
黑马头条1
java
宠友信息6 小时前
一套基于uniapp+springboot完整社区系统是如何实现的?友猫社区源码级功能解析
java·spring boot·后端·微服务·微信·uni-app
humors2216 小时前
各厂商工具包网址
java·数据库·python·华为·sdk·苹果·工具包
无限进步_6 小时前
【C++&string】大数相乘算法详解:从字符串加法到乘法实现
java·开发语言·c++·git·算法·github·visual studio
苏纪云6 小时前
蓝桥杯考前突击
c++·算法·蓝桥杯
W23035765737 小时前
经典算法详解:最长公共子序列 (LCS) —— 从暴力递归到动态规划完整实现
算法·动态规划·最长子序列
海兰7 小时前
使用 Spring AI 打造企业级 RAG 知识库第二部分:AI 实战
java·人工智能·spring
pzx_0017 小时前
【优化器】 随机梯度下降 SGD 详解
人工智能·python·算法