C++STL---vector常见用法

C++ STL中的vector

vector是C++标准模板库(STL)中最常用的序列容器之一,它是一个动态数组,能够存储任意类型的对象(如整数、字符串等)。vector的主要优点是提供了快速的随机访问,同时还能够动态地调整大小。

基本操作
  1. 创建和初始化

    #include <vector>
    std::vector<int> v1; // 创建一个空的vector
    std::vector<int> v2(5, 10); // 创建一个大小为5的vector,每个元素初始化为10
    std::vector<int> v3 = {1, 2, 3, 4, 5}; // 初始化列表
    
  2. 访问元素

    • at(index)operator[]:访问指定位置的元素,at会检查索引范围。
    • front()back():访问第一个和最后一个元素。
    int first = v3.front(); // 1
    int last = v3.back(); // 5
    int element = v3.at(2); // 3
    
  3. 修改元素

    • push_back(value):在vector的末尾添加一个元素。
    • pop_back():移除vector的最后一个元素。
    • insert(position, value):在指定位置插入一个元素。
    • erase(position)erase(start, end):删除一个或多个元素。
    • clear():清空所有元素。
    v3.push_back(6); // v3: {1, 2, 3, 4, 5, 6}
    v3.pop_back(); // v3: {1, 2, 3, 4, 5}
    v3.insert(v3.begin() + 2, 99); // v3: {1, 2, 99, 3, 4, 5}
    v3.erase(v3.begin() + 2); // v3: {1, 2, 3, 4, 5}
    
  4. 大小和容量

    • size():返回当前元素的数量。
    • capacity():返回vector在不重新分配内存的情况下可以存储的元素数量。
    • resize(n):改变vector的大小,多出的元素会被初始化。
    • reserve(n):增加vector的容量。
    size_t num_elements = v3.size(); // 5
    size_t capacity = v3.capacity();
    v3.reserve(10);
    
  5. 遍历

    • 使用范围for循环或迭代器。
    for (int x : v3) std::cout << x << " ";
    for (auto it = v3.begin(); it != v3.end(); ++it) std::cout << *it << " ";
    
相关算法

vector可以与STL中的算法库配合使用,提供强大的数据处理能力。

  1. 排序

    #include <algorithm>
    std::sort(v3.begin(), v3.end()); // 默认升序排序
    
  2. 查找

    auto it = std::find(v3.begin(), v3.end(), 3);
    if (it != v3.end()) {std::cout << "Element found: " << *it << std::endl;
    }
    
  3. 计数

    int count = std::count(v3.begin(), v3.end(), 3);
    
  4. 删除特定元素

    v3.erase(std::remove(v3.begin(), v3.end(), 3), v3.end());
    
  5. 遍历并执行操作

    std::for_each(v3.begin(), v3.end(), [](int& x){ x *= 2; });
    

删除特定元素代码是C++中使用的一种常见技术,结合了std::remove算法和erase成员函数来从容器中删除特定的元素。这种技术通常被称为“擦除-删除”惯用法(Erase-Remove Idiom)。下面是详细解释:

分解代码

d3.erase(std::remove(d3.begin(), d3.end(), 3), d3.end());
  1. std::remove(d3.begin(), d3.end(), 3)

    • std::remove是一个算法,它接受三个参数:开始迭代器、结束迭代器和要删除的值(这里是3)。
    • 这个函数并不实际从容器中删除元素,而是将不等于3的元素向容器的开始位置移动,并返回一个新的迭代器,指向移动后容器中最后一个有效元素之后的位置。
    • 也就是说,所有的3都被移到了容器的末尾,并且函数返回了一个指向第一个3的迭代器。
  2. d3.erase(new_end, d3.end())

    • erase是一个成员函数,用于从容器中实际删除元素。它接受两个迭代器作为参数:要删除的元素范围的开始和结束。
    • 在这里,erase函数使用从std::remove返回的迭代器(指向第一个3)作为起始位置,到容器的结束位置d3.end()作为结束位置。
    • 这个调用将删除所有的3,因为这些3现在都位于这个范围内。

效果

这行代码的效果是从容器d3中删除所有值为3的元素。这种方法比单独使用循环和条件删除更高效,因为它只需要一次遍历和少量的元素移动。

注意

  • 这种方法适用于支持快速随机访问的容器,如vectordequearray等。对于listforward_list这类容器,应使用成员函数remove,因为它们提供了更为优化的删除操作。
  • 使用std::remove时,容器的大小不会改变,只是元素的位置发生了变化,因此需要与erase结合使用来实际减少容器的大小。

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

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

相关文章

RPG Maker MV角色战斗动画记录

角色战斗动画记录 角色战斗状态判断的语句赋值 战斗管理战斗精灵创建精灵进行角色的更新 角色战斗状态 角色的战斗状态是由 Game_Battler 类中的 _actionState 属性的字符串决定的&#xff0c;它有哪些值呢&#xff1f; undecided 未确定或者说是操作状态inputting 输入waiti…

QA 未能打开位于 D:/Computer999/Computer999.vbox 的虚拟电脑

前言 未能打开位于 xxx/Computer999.vbox 的虚拟电脑&#xff0c;并提示E_INVALIDARG (0X80070057)&#xff0c;是最常见的一个错误&#xff0c;下面是解决办法。 内容 1、提示下面的错误&#xff0c;注册Computer999失败&#xff1a; 未能打开位于 D:/Computer999/Compute…

什么是封装?为什么是要封装?

封装是面向对象编程中的一种核心概念&#xff0c;它是将数据和操作数据的方法结合起来&#xff0c;形成一个整体&#xff0c;对外只暴露必要的接口&#xff0c;隐藏内部的具体实现细节。 封装的目的是为了实现信息隐藏和代码的模块化&#xff0c;具体原因如下&#xff1a; 1.…

K210视觉识别模块学习笔记1:第一个串口程序_程序烧录与开机启动

今日开始学习K210视觉识别模块:简单的认识与串口程序 亚博智能的K210视觉识别模块...... 固件库版本: canmv_yahboom_v2.1.1.bin 既然K210作为一个视觉识别外设模块来使用&#xff0c;我认为第一个程序 就没必要学点灯之类的了&#xff0c;直接学习串口如何配置开始为妥&…

5分钟懂一个前端知识点系列之this关键字

前言 本人在学习this和原型&#xff08;特别是this指向&#xff09;的时候遇到了些许困惑&#xff0c;今天跟大家详细解释一下我在学习路上对this和原型的了解。难点先来攻克&#xff0c;今天先来讲讲this。这里统一声明不讨论严格模式下面的使用&#xff0c;因为我也不了解不…

ctfshow-web入门-爆破(web21-web24)

目录 1、web21 2、web22 3、web23 4、web24 1、web21 爆破什么的&#xff0c;都是基操 需要认证才能访问 随便输一个用户名和密码抓包看看&#xff1a; 多出来一个认证的头 Authorization: Basic YWRtaW46MTIzNDU2 base64 解码看看&#xff1a; 就是我们刚才输入的用于测…

C语言 | Leetcode C语言题解之第127题单词接龙

题目&#xff1a; 题解&#xff1a; struct Trie {int ch[27];int val; } trie[50001];int size, nodeNum;void insert(char* s, int num) {int sSize strlen(s), add 0;for (int i 0; i < sSize; i) {int x s[i] - ;if (trie[add].ch[x] 0) {trie[add].ch[x] size;m…

计算机系统结构之FORK和JOIN

程序语言中用FORK语句派生并行任务&#xff0c;用JOIN语句对多个并发任务汇合。 FORK语句的形式为FORK m&#xff0c;其中m为新领程开始的标号。 JOIN语句的形式为JOIN n&#xff0c;其中n为并发进程的个数。 例1&#xff1a;给定算术表达式ZEA*B*C/DF经并行编译得到如下程序…

刘强东的简历很拉风!

正式宣布&#xff1a;GPT 4o 在国内直接使用 ~ 来看一下江湖人称“东哥”刘强东的简历&#xff0c;大佬确实很拉风&#xff1a; 刘强东&#xff0c;京东的创始人&#xff0c;是中国互联网行业的传奇人物。他的故事充满了奋斗和创新&#xff0c;以下是我对他简历的一些看法&…

spring中处理跨域的3种方案

前言 跨域是指一个域下的文件想要和另一个域下的资源发生HTTP通信时,浏览器出于安全限制所引发的问题。如果协议、子域名、主域名、端口有任何一个不同,都会出现跨域问题。 举个例子,如果一个网页来自https://www.example.com,那么它只能访问同域下的资源,如https://www.exam…

元组的常用操作小结

元组的常用操作小结 元组&#xff08;Tuple&#xff09;是一种不可变的容器&#xff0c;可以存储多个值。下面是元组的常用操作和示例&#xff1a; 创建元组 # 创建一个简单的元组 my_tuple (apple, banana, cherry)print(my_tuple) # 输出&#xff1a;(apple, banana, ch…

GPG简介

简介 The GNU Privacy Guard GnuPG 是 RFC4880 定义的 OpenPGP 标准&#xff08;也称为 PGP&#xff09;的完整且免费的实现。GnuPG 允许您加密和签署您的数据和通信;它具有多功能的密钥管理系统&#xff0c;以及用于各种公钥目录的访问模块。GnuPG&#xff0c;也称为 GPG&…

Vitis HLS 学习笔记--HLS流水线类型

目录 1. 简介 2. 优缺点对比 2.1 Stalled Pipeline 2.2 Free-Running/Flushable Pipeline 2.3 Flushable Pipeline 3. 设置方法 4. FRP的特殊优势 5. 总结 1. 简介 Vitis HLS 会自动选择正确的流水线样式&#xff0c;用于流水打拍函数或循环。 停滞的流水线&#xff…

K8S SWCK SkyWalking全链路跟踪工具安装

官方参考&#xff1a;如何使用java探针注入器? 配置两个demo&#xff0c;建立调用关系&#xff0c; 首先创建一个基础镜像dockerfile from centos 先安装java 参考: linux rpm方式安装java JAVA_HOME/usr/java/jdk1.8.0-x64 CLASSPATH.:$JAVA_HOME/lib/tools.jar PATH…

了解Maven,并配置国内源

目录 1.了解Maven 1.1什么是Maven 1.2快速创建一个Maven项⽬ 1.3Maven 核⼼功能 1.3.1项⽬构建 1.3.2依赖管理 1.4Maven Help插件 2.Maven 仓库 2.1中央仓库 2.2本地仓库 3.Maven 设置国内源 1.查看配置⽂件的地址 2.配置国内源 3.设置新项⽬的setting 1.了解Ma…

Hive安装-内嵌模式

1.官网下在hive3.1.2版本 Index of /dist/hive/hive-3.1.2 2.上传到master节点的/opt/software目录下 3.解压到/opt/module目录下 tar -zxvf apache-hive-3.1.2-bin.tar.gz -C /opt/module/ 检查解压后文件 4.修改名字 改为hive cd /opt/module mv apache-hive-3.1.2-bin…

期权的时间价值是什么?和期权内在价值有啥不同?

今天带你了解期权的时间价值是什么&#xff1f;和期权内在价值有啥不同&#xff1f;期权的内在价值&#xff0c;是指期权立即执行产生的经济价值。 期权的时间价值是什么&#xff1f; 期权的时间价值是期权价格的一个重要组成部分&#xff0c;也被称为期权的外在价值。它是指期…

【再探】设计模式—备忘录模式与解释器模式

备忘录模式是用于保存对象在某个时刻的状态&#xff0c;来实现撤销操作。而解释器模式则是将文本按照定义的文法规则解析成对应的命令。 1 备忘录模式 需求&#xff1a;保存对象在某个时刻的状态&#xff0c;后面可以对该对象实行撤销操作。 1.1 备忘录模式介绍 提供一种状…

RK3568笔记二十九:RTMP推流

若该文为原创文章&#xff0c;转载请注明原文出处。 基于RK3568的RTMP推流测试&#xff0c;此代码是基于勇哥的github代码修改的&#xff0c;源码地址MontaukLaw/3568_rknn_rtmp: rk3568的推理推流 (github.com) 感兴趣的可以clone下来测试。 也可以下载修改后的代码测试。Y…

【面试宝藏】Go并发编程面试题

深入Go语言并发编程 Go语言以其简洁、高效的并发处理能力而闻名。在Go中&#xff0c;通过各种同步机制和原子操作&#xff0c;可以轻松地实现高性能并发编程。本文将深入探讨Go语言中的并发编程&#xff0c;包括Mutex、RWMutex、Cond、WaitGroup、原子操作等内容。 1. Mutex几…