最长的连续序列到底怎么写

原来数组里面元素的顺序是无所谓的。

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

        int longest_sequence_length = 0;
        for ( auto& it: hash_set ) {
            if ( !hash_set.count( it - 1 ) ) {
                int current_number = it;
                int tentative_sequence_length = 1;

                while ( hash_set.count(current_number + 1 )) {
                    current_number += 1;
                    tentative_sequence_length += 1;
                }

                longest_sequence_length = max(longest_sequence_length, tentative_sequence_length);
            }
        }

        return longest_sequence_length;
    }
};

核心就是要跳过一些元素。我们判断到某一个元素,比这个元素小 1 存在,我们就跳过了。比如说遍历到一个元素 it = 4, 但是我们判断出来,在无序哈希集合 unordered_set hash_set 里面,存在 3,也就是,hash_set.count(it-1)==1,那么我们就不需要判断 4 开头的序列了,因为 3 开头的我们就判断过了。也就是说,我们每个元素在遍历到的时候,都会判断一次,这个时间是线性的。

第二,我们判断一个元素,我们会用一个循环,判断后面是否存在连续的元素,如果存在,会持续地循环下去。也就是说,我们至多,循环 2 个线性的时间,从渐进意义上面来分析,还是线性的时间。考虑极端的情况,找的第一个元素就是,连续序列的第一个元素,while 循环会持续到最后一个最大的元素,把所有的元素都遍历了一遍,消耗了线性的时间,然后退回到 for( auto& it: hash_set) 这个循环,遍历一次,判断一次,但是不会再进入到 while 循环了。所以可以得到一个极大的优化。

相关推荐
汀、人工智能3 小时前
[特殊字符] 第40课:二叉树最大深度
数据结构·算法·数据库架构·图论·bfs·二叉树最大深度
沉鱼.443 小时前
第十二届题目
java·前端·算法
大熊背3 小时前
ISP Pipeline中Lv实现方式探究之三--lv计算定点实现
数据结构·算法·自动曝光·lv·isppipeline
西岸行者4 小时前
BF信号是如何多路合一的
算法
大熊背4 小时前
ISP Pipeline中Lv实现方式探究之一
算法·自动白平衡·自动曝光
罗西的思考5 小时前
【OpenClaw】通过 Nanobot 源码学习架构---(5)Context
人工智能·算法·机器学习
Liudef066 小时前
后量子密码学(PQC)深度解析:算法原理、标准进展与软件开发行业的影响
算法·密码学·量子计算
OYpBNTQXi7 小时前
SEAL全同态加密CKKS方案入门详解
算法·机器学习·同态加密
蚂蚁数据AntData7 小时前
破解AI“机器味“困境:HeartBench评测实践详解
大数据·人工智能·算法·机器学习·语言模型·开源
ZC跨境爬虫7 小时前
Python异步IO详解:原理、应用场景与实战指南(高并发爬虫首选)
爬虫·python·算法·自动化