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;

    }
};
相关推荐
会员源码网7 小时前
使用`mysql_*`废弃函数(PHP7+完全移除,导致代码无法运行)
后端·算法
木心月转码ing8 小时前
Hot100-Day10-T438T438找到字符串中所有字母异位词
算法
HelloReader8 小时前
Wi-Fi CSI 感知技术用无线信号“看见“室内的人
算法
颜酱11 小时前
二叉树分解问题思路解题模式
javascript·后端·算法
qianpeng89712 小时前
水声匹配场定位原理及实验
算法
董董灿是个攻城狮1 天前
AI视觉连载8:传统 CV 之边缘检测
算法
AI软著研究员1 天前
程序员必看:软著不是“面子工程”,是代码的“法律保险”
算法
FunnySaltyFish1 天前
什么?Compose 把 GapBuffer 换成了 LinkBuffer?
算法·kotlin·android jetpack
颜酱1 天前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法
地平线开发者2 天前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶