3.最长连续序列

给定一个未排序的整数数组 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

思路:本题用哈希表的set比较方便,set可以去重。

1.定义一个set,把nums的所有元素放进去,并去重。

2.for循环遍历set,对每个元素,先判断是不是序列的起点(看看set中有没有比它小1的数字),如果是起点,就定义x=i+1;用while循环查询set中有无比该元素大1的元素,如果有就让x++;

3.在while循环结束后,找ans和x-i的大值赋值给ans。

复制代码
class Solution {
public:
    int longestConsecutive(vector<int>& nums) {
        unordered_set<int> set(nums.begin(),nums.end());
        int ans=0;
        for(int i:set)
        {
            if(!set.count(i-1))
            {
                int x=i+1;
                while(set.count(x))x++;
                ans=max(ans,x-i);
                
            }

        }
        return ans;

    }
};
相关推荐
superlls2 小时前
(算法 哈希表)【LeetCode 349】两个数组的交集 思路笔记自留
java·数据结构·算法
田里的水稻2 小时前
C++_队列编码实例,从末端添加对象,同时把头部的对象剔除掉,中的队列长度为设置长度NUM_OBJ
java·c++·算法
纪元A梦2 小时前
贪心算法应用:保险理赔调度问题详解
算法·贪心算法
Ripple123123 小时前
数据结构:顺序表与链表
数据结构·链表
Jayden_Ruan3 小时前
C++逆向输出一个字符串(三)
开发语言·c++·算法
一个响当当的名号4 小时前
B树,B+树,B*树(无代码)
数据结构·b树
点云SLAM4 小时前
C++ 常见面试题汇总
java·开发语言·c++·算法·面试·内存管理
叙白冲冲4 小时前
哈希算法以及面试答法
算法·面试·哈希算法
YuTaoShao5 小时前
【LeetCode 每日一题】1277. 统计全为 1 的正方形子矩阵
算法·leetcode·矩阵
古译汉书5 小时前
嵌入式铁头山羊stm32-ADC实现定时器触发的注入序列的单通道转换-Day26
开发语言·数据结构·stm32·单片机·嵌入式硬件·算法