【LeetCode】128. 最长连续序列

题目

128. 最长连续序列

思路

每个数都判断一次这个数是不是连续序列的开头那个数。用哈希表查找这个数前面一个数是否存在,即num-1在序列中是否存在。如果存在则这个数肯定不是开头,跳过。因此只需要对每个开头的数进行循环,直到这个序列不再连续。

100,4,200,1,3,4,2

去重后的哈希序列为:

100,4,200,1,3,2

按照上面逻辑进行判断:

1.元素100是开头,因为没有99,且以100开头的序列长度为1

2.元素4不是开头,因为有3存在,过

3.元素200是开头,因为没有199,且以200开头的序列长度为1

4.元素1是开头,因为没有0,且以1开头的序列长度为4,因为依次累加,2,3,4都存在。

5.元素3不是开头,因为2存在,过,

6.元素2不是开头,因为1存在,过。

代码

cpp 复制代码
class Solution {
public:
    int longestConsecutive(vector<int>& nums) {
        unordered_set<int> num_set;
        for (const int& num : nums) {
            num_set.insert(num);
        }

        int longestStreak = 0;

        for (const int& num : num_set) {
            if (!num_set.count(num - 1)) {
                int currentNum = num;
                int currentStreak = 1;

                while (num_set.count(currentNum + 1)) {
                    currentNum += 1;
                    currentStreak += 1;
                }

                longestStreak = max(longestStreak, currentStreak);
            }
        }

        return longestStreak;           
    }
};
相关推荐
白羊by2 小时前
YOLOv1~v11 全版本核心演进总览
深度学习·算法·yolo
墨尘笔尖4 小时前
最大最小值降采样算法的优化
c++·算法
white-persist6 小时前
【vulhub shiro 漏洞复现】vulhub shiro CVE-2016-4437 Shiro反序列化漏洞复现详细分析解释
运维·服务器·网络·python·算法·安全·web安全
FL16238631296 小时前
基于C#winform部署软前景分割DAViD算法的onnx模型实现前景分割
开发语言·算法·c#
baizhigangqw7 小时前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶
算法·启发式算法·web app
C雨后彩虹7 小时前
最多等和不相交连续子序列
java·数据结构·算法·华为·面试
cpp_25018 小时前
P2347 [NOIP 1996 提高组] 砝码称重
数据结构·c++·算法·题解·洛谷·noip·背包dp
Hugh-Yu-1301238 小时前
二元一次方程组求解器c++代码
开发语言·c++·算法
编程大师哥8 小时前
C++类和对象
开发语言·c++·算法
加农炮手Jinx9 小时前
LeetCode 146. LRU Cache 题解
算法·leetcode·力扣