数组中的最长连续子序列

数组中的最长连续子序列_牛客题霸_牛客网

思路:将给出的数按顺序排序,然后按顺序计算,如果前后差值为1,开始迭代计数,然后与最大值比较,如果大于就更新。时间复杂度要求O(NlogN)。1.可以使用set,set自带去重和排序功能,十分适合做本题。set底层为红黑树,建成一个树的时间复杂度为O(NlogN),空间复杂度为O(N),不过由于是结点,所以系数肯定会大一些;

也可以用另一种set的构造函数:

2.还有一种方法,先用sort对给定的数组进行排序,再用unique函数去重,然后再用erase函数删除无效数据,就达到了与set一样的效果,并且空间消耗要小一些,时间复杂度也是O(NlogN)。这里着重看一下unique的用法

std::unique 是 C++ STL <algorithm> 里的函数,用于 去除相邻的重复元素 ,只保留每个元素第一次出现的位置,并返回新逻辑末尾迭代器。它不会真正删除元素,只是将重复内容移动到后面 。要真正删除,需要配合 erase()

复制代码
#include <algorithm>
#include <vector>
#include <iostream>
using namespace std;

int main() {
    vector<int> v = {1, 1, 2, 2, 2, 3, 3, 4};

    auto last = unique(v.begin(), v.end());
    v.erase(last, v.end()); // 真的删除重复部分

    for(int x : v) cout << x << " ";
}

输出:

复制代码
1 2 3 4

只处理相邻重复

如果元素不连续,unique 不会帮你排序或去重:

复制代码
vector<int> v = {3, 1, 2, 1, 2};
unique(v.begin(), v.end()); // 没有作用,因为相邻元素没重复

所以常见用法是:

复制代码
sort + unique

重载支持自定义比较

复制代码
unique(v.begin(), v.end(), [](int a, int b){
    return abs(a - b) < 3; // 自定义"相等"规则
});

返回值

内容 解释
返回迭代器 指向去重后"逻辑有效区间的末尾"
原容器长度不变 只是元素被移动,末尾部分无意义

举个例子看一看unique的过程:

1222344

复制代码
索引:   0 1 2 3 4 5 6
数据:   1 2 2 2 3 4 4

设:

复制代码
write = 0
read  = 1

规则:

  • 如果 v[read] != v[write] → 表示新值,把它写进 write+1 位置,并 write++

  • 如果相等 → 跳过

步骤 read write 判断 修改后数组(带解释)
初始 1 0 --- 1 2 2 2 3 4 4
Step1 1 0 2 != 1 → 写入 1 2 2 2 3 4 4(写入到原位置,无变化)→ write=1
Step2 2 1 2 == 2 → 跳过 1 2 2 2 3 4 4
Step3 3 1 2 == 2 → 跳过 1 2 2 2 3 4 4
Step4 4 1 3 != 2 → 写入 写入 index=2 → 1 2 3 2 3 4 4 → write=2
Step5 5 2 4 != 3 → 写入 写入 index=3 → 1 2 3 4 3 4 4 → write=3
Step6 6 3 4 == 4 → 跳过 1 2 3 4 3 4 4
相关推荐
NAGNIP12 小时前
一文搞懂机器学习中的特征降维!
算法·面试
NAGNIP12 小时前
一文搞懂机器学习中的特征构造!
算法·面试
Learn Beyond Limits12 小时前
解构语义:从词向量到神经分类|Decoding Semantics: Word Vectors and Neural Classification
人工智能·算法·机器学习·ai·分类·数据挖掘·nlp
你怎么知道我是队长13 小时前
C语言---typedef
c语言·c++·算法
Qhumaing14 小时前
C++学习:【PTA】数据结构 7-1 实验7-1(最小生成树-Prim算法)
c++·学习·算法
Z1Jxxx16 小时前
01序列01序列
开发语言·c++·算法
汽车仪器仪表相关领域17 小时前
全自动化精准检测,赋能高效年检——NHD-6108全自动远、近光检测仪项目实战分享
大数据·人工智能·功能测试·算法·安全·自动化·压力测试
Doro再努力18 小时前
【数据结构08】队列实现及练习
数据结构·算法
清铎19 小时前
leetcode_day12_滑动窗口_《绝境求生》
python·算法·leetcode·动态规划