数组中的最长连续子序列

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

思路:将给出的数按顺序排序,然后按顺序计算,如果前后差值为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
相关推荐
摇摆的含羞草7 分钟前
哈希(hash)算法使用特点及常见疑问解答
算法·哈希算法
Fine姐33 分钟前
数据结构04——二叉树搜索树BST
数据结构
仰泳的熊猫43 分钟前
1077 Kuchiguse
数据结构·c++·算法·pat考试
LYFlied1 小时前
【每日算法】LeetCode 19. 删除链表的倒数第 N 个结点
算法·leetcode·链表
阿里巴巴AI编程社区1 小时前
Qoder 提效实战:数据开发工程师用 Qoder 提效50%
数据结构
踏浪无痕1 小时前
计算机算钱为什么会算错?怎么解决?
后端·算法·面试
消失的旧时光-19431 小时前
从 C 链表到 Android Looper:MessageQueue 的底层原理一条线讲透
android·数据结构·链表
夏乌_Wx1 小时前
练题100天——DAY28:找消失的数字+分发饼干
数据结构·算法
lzh200409191 小时前
二叉搜索树与双向链表
数据结构·链表
studytosky2 小时前
深度学习理论与实战:反向传播、参数初始化与优化算法全解析
人工智能·python·深度学习·算法·分类·matplotlib