C++学习笔记(三十九)——STL之删除算法

news2025/4/26 22:03:51

STL 算法分类:

类别常见算法作用
排序sortstable_sortpartial_sortnth_element排序
搜索findfind_ifcountcount_ifbinary_search查找元素
修改copyreplacereplace_ifswapfill修改容器内容
删除removeremove_ifunique删除元素
归约for_eachaccumulate处理数据
合并mergeset_unionset_intersection处理有序序列
排列组合next_permutationprev_permutation生成排列
堆操作push_heappop_heapmake_heapsort_heap处理堆

STL 删除算法

STL 删除算法是 C++ 标准库中的一类算法,它们用于从容器中删除元素。常用的删除算法包括 removeremove_ifunique 等。
删除算法广泛应用于容器中元素的移除、重复元素的去重等操作。

算法名称功能描述时间复杂度空间复杂度适用场景
remove删除容器中指定值的元素(逻辑删除,需要容器的内部函数eraseO(n)O(1)删除容器中的指定值元素
remove_if删除容器中满足条件的元素(逻辑删除,需要 eraseO(n)O(1)根据条件删除容器中的元素
unique删除相邻重复的元素(逻辑删除,需要 eraseO(n)O(1)删除相邻重复的元素(去重)
erase直接删除容器中指定值的元素(C++20)O(n)O(1)简化版的删除指定值元素
erase_if直接删除容器中满足条件的元素(C++20)O(n)O(1)根据条件直接删除容器中的元素

(1)remove

  • 功能:将容器中所有等于指定值的元素移除,并返回指向新序列的末尾后一位置的迭代器。
    注意,remove 并不会真正删除元素,而是将这些元素“移动”到容器末尾,并返回一个新的逻辑结束位置。要实际删除这些元素,还需要配合 erase 方法使用。
  • 时间复杂度O(n),其中 n 是容器中的元素数量。
  • 空间复杂度O(1),原地操作。

示例:

#include <iostream>
using namespace std;
#include <vector>
#include <algorithm>

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

    // 删除所有值为 2 的元素
    vec.erase(remove(vec.begin(), vec.end(), 2), vec.end());

    cout << "删除后: ";
    for (int val : vec)
    {
        cout << val << " ";
    }
    cout << endl;

    system("pause");
    return 0;
}

注意:

  • remove适用于,当需要从容器中删除指定值的元素时。

(2)remove_if

  • 功能:根据指定的条件删除容器中的元素。该算法将所有满足条件的元素移除,并返回指向新序列的末尾后一位置的迭代器。
    remove 类似,remove_if 不会真正删除元素,需要配合 erase 使用。
  • 时间复杂度O(n),其中 n 是容器中的元素数量。
  • 空间复杂度O(1),原地操作。

示例:

#include <iostream>
using namespace std;
#include <vector>
#include <algorithm>

bool is_even(int n)
{
    return n % 2 == 0;
}

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

    // 删除所有偶数元素
    vec.erase(remove_if(vec.begin(), vec.end(), is_even), vec.end());

    cout << "在 remove_if删除后: ";
    for (int val : vec) 
    {
        cout << val << " ";
    }
    cout << endl;

    system("pause");
    return 0;
}

注意:

  • remove_if适用于,当需要根据条件删除容器中的元素时。

(3) unique

  • 功能:删除容器中的相邻重复元素,只保留一个重复元素,返回指向去重后的末尾的迭代器(即末尾元素的后一位置)。
    注意,unique 只去除相邻的重复元素,如果容器中的元素不相邻,则不做任何操作。unique 通常与 erase 配合使用来移除元素。
  • 时间复杂度O(n),其中 n 是容器中的元素数量。
  • 空间复杂度O(1),原地操作。

示例:

#include <iostream>
using namespace std;
#include <vector>
#include <algorithm>

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

    // 去除相邻重复的元素
    vec.erase(unique(vec.begin(), vec.end()), vec.end());

    cout << "在 unique去重后: ";
    for (int val : vec)
    {
        cout << val << " ";
    }
    cout << endl;

    system("pause");
    return 0;
}

注意:

  • unique适用于,当需要删除相邻重复元素时。

(4)erase(C++20)

  • 功能:从容器中直接删除元素,简化了 removeerase 的组合使用,适用于标准容器(如 vector, deque, list 等)。
  • 时间复杂度O(n),其中 n 是容器中的元素数量。
  • 空间复杂度O(1)

示例:

#include <iostream>
using namespace std;
#include <vector>
#include <algorithm>

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

    // C++20 中直接使用 erase 删除值为 2 的元素
    erase(vec, 2);

    cout << "After erase: ";
    for (int val : vec)
    {
        cout << val << " ";
    }
    cout << endl;

    system("pause");
    return 0;
}

注意:

  • erase用于直接删除容器中的元素。

(5)erase_if(C++20)

  • 功能:根据指定条件直接删除满足条件的元素,简化了 remove_iferase 的组合使用。
  • 时间复杂度O(n),其中 n 是容器中的元素数量。
  • 空间复杂度O(1)

示例:

#include <iostream>
using namespace std;
#include <vector>
#include <algorithm>

bool is_even(int n) 
{
    return n % 2 == 0;
}

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

    // C++20 中直接使用 erase_if 删除偶数元素
    erase_if(vec, is_even);

    cout << "erase_if后: ";
    for (int val : vec)
    {
        cout << val << " ";
    }
    cout << endl;

    system("pause");
    return 0;
}

注意:

  • erase_if用于根据条件直接删除容器中的元素。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2343569.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于线性LDA算法对鸢尾花数据集进行分类

基于线性LDA算法对鸢尾花数据集进行分类 1、效果 2、流程 1、加载数据集 2、划分训练集、测试集 3、创建模型 4、训练模型 5、使用LDA算法 6、画图3、示例代码 # 基于线性LDA算法对鸢尾花数据集进行分类# 基于线性LDA算法对鸢尾花数据集进行分类 import numpy as np import …

【Deepseek基础篇】--v3基本架构

目录 MOE参数 1.基本架构 1.1. Multi-Head Latent Attention多头潜在注意力 1.2.无辅助损失负载均衡的 DeepSeekMoE 2.多标记预测 2.1. MTP 模块 论文地址&#xff1a;https://arxiv.org/pdf/2412.19437 DeepSeek-V3 是一款采用 Mixture-of-Experts&#xff08;MoE&…

centos7使用yum快速安装最新版本Jenkins-2.462.3

Jenkins支持多种安装方式&#xff1a;yum安装、war包安装、Docker安装等。 官方下载地址&#xff1a;https://www.jenkins.io/zh/download 本次实验使用yum方式安装Jenkins LTS长期支持版&#xff0c;版本为 2.462.3。 一、Jenkins基础环境的安装与配置 1.1&#xff1a;基本…

【vue】【element-plus】 el-date-picker使用cell-class-name进行标记,type=year不生效解决方法

typedete&#xff0c;自定义cell-class-name打标记效果如下&#xff1a; 相关代码&#xff1a; <el-date-pickerv-model"date":clearable"false":editable"false":cell-class-name"cellClassName"type"date"format&quo…

c++11新特性随笔

1.统一初始化特性 c98中不支持花括号进行初始化&#xff0c;编译时会报错&#xff0c;在11当中初始化可以通过{}括号进行统一初始化。 c98编译报错 c11: #include <iostream> #include <set> #include <string> #include <vector>int main() {std:…

C++23 中 constexpr 的重要改动

文章目录 1. constexpr 函数中使用非字面量变量、标号和 goto (P2242R3)示例代码 2. 允许 constexpr 函数中的常量表达式中使用 static 和 thread_local 变量 (P2647R1)示例代码 3. constexpr 函数的返回类型和形参类型不必为字面类型 (P2448R2)示例代码 4. 不存在满足核心常量…

全面解析React内存泄漏:原因、解决方案与最佳实践

在开发React应用时&#xff0c;内存泄漏是一个常见但容易被忽视的问题。如果处理不当&#xff0c;它会导致应用性能下降、卡顿甚至崩溃。由于React的组件化特性&#xff0c;许多开发者可能没有意识到某些操作&#xff08;如事件监听、异步请求、定时器等&#xff09;在组件卸载…

【FreeRTOS】事件标志组

文章目录 1 简介1.1事件标志1.2事件组 2事件标志组API2.1创建动态创建静态创建 2.2 删除事件标志组2.3 等待事件标志位2.4 设置事件标志位在任务中在中断中 2.5 清除事件标志位在任务中在中断中 2.6 获取事件组中的事件标志位在任务中在中断中 2.7 函数xEventGroupSync 3 事件标…

超级扩音器手机版:随时随地,大声说话

在日常生活中&#xff0c;我们常常会遇到手机音量太小的问题&#xff0c;尤其是在嘈杂的环境中&#xff0c;如KTV、派对或户外活动时&#xff0c;手机自带的音量往往难以满足需求。今天&#xff0c;我们要介绍的 超级扩音器手机版&#xff0c;就是这样一款由上海聚告德业文化发…

【数据可视化-27】全球网络安全威胁数据可视化分析(2015-2024)

&#x1f9d1; 博主简介&#xff1a;曾任某智慧城市类企业算法总监&#xff0c;目前在美国市场的物流公司从事高级算法工程师一职&#xff0c;深耕人工智能领域&#xff0c;精通python数据挖掘、可视化、机器学习等&#xff0c;发表过AI相关的专利并多次在AI类比赛中获奖。CSDN…

【6G 开发】NV NGC

配置 生成密钥 API Keys 生成您自己的 API 密钥&#xff0c;以便通过 Docker 客户端或通过 NGC CLI 使用 Secrets Manager、NGC Catalog 和 Private Registry 的 NGC 服务 以下个人 API 密钥已成功生成&#xff0c;可供此组织使用。这是唯一一次显示您的密钥。 请妥善保管您的…

SIEMENS PLC程序解读 -Serialize(序列化)SCATTER_BLK(数据分散)

1、程序数据 第12个字节 PI 2、程序数据 第16个字节 PI 3、程序数据 第76个字节 PO 4、程序代码 2、程序解读 图中代码为 PLC 梯形图&#xff0c;主要包含以下指令及功能&#xff1a; Serialize&#xff08;序列化&#xff09;&#xff1a; 将 SRC_VARIABLE&#xff…

宁德时代25年时代长安动力电池社招入职测评SHL题库Verify测评语言理解数字推理真题

测试分为语言和数字两部分&#xff0c;测试时间各为17分钟&#xff0c;测试正式开始后不能中断或暂停

【硬核解析:基于Python与SAE J1939-71协议的重型汽车CAN报文解析工具开发实战】

引言&#xff1a;重型汽车CAN总线的数据价值与挑战 随着汽车电子化程度的提升&#xff0c;控制器局域网&#xff08;CAN总线&#xff09;已成为重型汽车的核心通信网络。不同控制单元&#xff08;ECU&#xff09;通过CAN总线实时交互海量报文数据&#xff0c;这些数据隐藏着车…

Uniapp 自定义 Tabbar 实现教程

Uniapp 自定义 Tabbar 实现教程 1. 简介2. 实现步骤2.1 创建自定义 Tabbar 组件2.2 配置 pages.json2.3 在 App.vue 中引入组件 3. 实现过程中的关键点3.1 路由映射3.2 样式设计3.3 图标处理 4. 常见问题及解决方案4.1 页面跳转问题4.2 样式适配问题4.3 性能优化 5. 扩展功能5.…

记录一次使用面向对象的C语言封装步进电机驱动

简介 (2025/4/21) 本库对目前仅针对TB6600驱动下的42步进电机的基础功能进行了一定的封装, 也是我初次尝试以面向对象的思想去编写嵌入式代码, 和直流电机的驱动步骤相似在调用stepmotor_attach()函数和stepmotor_init()函数之后仅通过结构体数组stepm然后指定枚举变量中的id即…

Spark-streaming核心编程

1.导入依赖‌&#xff1a; <dependency> <groupId>org.apache.spark</groupId> <artifactId>spark-streaming-kafka-0-10_2.12</artifactId> <version>3.0.0</version> </dependency> 2.编写代码‌&#xff1a; 创建Sp…

vue3+TS+echarts 折线图

需要实现的效果如下 <script setup lang"ts" name"RepsSingleLineChart">import * as echarts from echartsimport { getInitecharts } from /utils/echartimport type { EChartsOption } from echarts// 定义 props 类型interface Props {id: strin…

小火电视桌面TV版下载-小火桌面纯净版下载-官方历史版本安装包

别再费心地寻找小火桌面的官方历史版本安装包啦&#xff0c;试试乐看家桌面吧&#xff0c;它作为纯净版本的第三方桌面&#xff0c;具有诸多优点。 界面简洁纯净&#xff1a;乐看家桌面设计简洁流畅&#xff0c;页面简洁、纯净无广告&#xff0c;为用户打造了一个干净的电视操…

androidstudio安装配置

B站配置视频AndroidStudio安装配置教程&#xff08;最新版本教程&#xff09;3分钟搞定 快速安装使用_哔哩哔哩_bilibili 1、环境变量 D:\AndroidSdk ANDROID_HOME ANDROID_SDK_HOME 2、新建 3、配置 distributionUrlhttps://mirrors.cloud.tencent.com/gradle/gradle-8.11.1-…