【C++】STL—vector的使用

目录

  • 前言
  • vector的常见构造
  • 迭代器的使用
  • vector空间增长问题
  • vector的增删查改
    • 尾插和尾删
    • find
    • insert和erase

请添加图片描述

前言

  vector是表示可变大小数组的序列容器。它就像数组一样,采用连续的存储空间来存储元素,且它的大小可以动态改变。并且vector在访问元素时也非常高效,在末尾添加和删除元素也相对高效,对于其它不在末尾的删除和插入操作,效率还是比较低下的,这和前面学习的顺序表是差不多的,但是结构完全不同:
在这里插入图片描述
大家可以通过查看库里面的函数来学习:cplusplus-vector

vector的常见构造

(constructor)构造函数声明接口声明
vector(重点)无参构造
vector(size_t nsize_type n, const value_type& val = value_type())构造并初始化n个val
vector(const vector& x)(重点)拷贝构造
vector(InputIterator first,InputIterator last)使用迭代器进行初始化构造
vector<int> v1;//无参构造vector<char> v2(10, 'x');//构造并用10个x进行初始化string s("abcdef");
vector<char> v3(s.begin(), s.end());//使用迭代器进行初始化vector<char> v4(v3);//拷贝构造

迭代器的使用

iterator的使用接口说明
begin+end(重点)获取第一个数据位置的iterator/const_iterator,获取最后一个数据的下一个位置的iterator/const_iterator
rbegin+rend获取最后一个数据位置的reverse_iterator,获取第一个数据前一个位置的reverse_iterator

在这里插入图片描述

vector<char> v1(10, 'x');
vector<char>::iterator it1 = v1.begin();
while (it1 != v1.end())
{cout << *it1 << " ";it1++;
}
cout << endl;
for (auto e : v1)
{cout << e << " ";
}
cout << endl;
vector<char>::reverse_iterator rit1 = v1.rbegin();//反向迭代器
while (rit1 != v1.rend())
{cout << *rit1 << " ";rit1++;
}
cout << endl;const vector<char> v2(10, 'a');//只读的迭代器
vector<char>::const_iterator it2 = v2.begin();
while (it2 != v2.end())
{//*it2 += 3;cout << *it2 << " ";it2++;}
cout << endl;
vector<char>::const_reverse_iterator rit2 = v2.rbegin();//反向迭代器
while (rit2 != v2.rend())
{cout << *rit2 << " ";rit2++;
}
cout << endl;

vector空间增长问题

容量空间接口说明
size获取数据个数
capacity获取容量大小
empty判断是否为空
resize(重点)改变vector的size
reserve(重点)改变vector的capacity
vector<int> v1 = { 1,2,3,4,5 };
cout << "v1的size:" << v1.size() << endl;
cout << "v1的capacity:" << v1.capacity() << endl;
cout << "v1是否为空:" << v1.empty() << endl;

对于vector的扩容问题,我们可以通过一段代码来看一下:

//测试vector的扩容机制
size_t sz;
vector<int> v;
sz = v.capacity();
cout << sz << endl;
cout << "making v grow" << endl;
for (int i = 0; i < 100; i++)
{v.push_back(i);if (sz != v.capacity())//不相等则出现扩容{sz = v.capacity();cout << "capacity changed:" << sz << endl;}
}

在这里插入图片描述
  通过结果我们可以发现,vs2022下的vector增长大致是以1.5倍进行增长的,如果大家有Linux,可以再验证一下,在Linux下vector则是以2倍进行增长的。
  所以我们可以通过使用reserve来扩容,提前开好空间,且不会造成过多的内存碎片。
  和string一样,resize既改变了size又影响了capacity。

vector的增删查改

vector增删查改接口说明
push_back(重点)尾插
pop_back(重点)尾删
find查找(存在于算法< alalgorithm>这个头文件中,并不属于vector的成员接口)
insert在position之前插入val
erase删除position位置的数据
swap交换两个vector的数据空间
operator[]像数组一样访问

尾插和尾删

这两者使用起来还是比较简单的,

vector<int> v1;
v1.push_back(1);
v1.push_back(2);
v1.push_back(3);
v1.push_back(4);
for (int i = 0; i < v1.size(); i++)
{cout << v1[i] << " ";//可以像数组一样访问
}
cout << endl;
v1.pop_back();//尾删 1 2 3

find

  find是在算法模块中的,不属于vector的成员接口。
  它是在迭代器区间[first,last)内查找某个元素,若能查找到,则返回第一个元素的迭代器,若找不到,则返回last的迭代器。
在这里插入图片描述

insert和erase

在这里插入图片描述
在这里插入图片描述
  通过库里面的insert和erase函数发现两个函数的参数都包含了迭代器,find返回的就是迭代器,因此可以通过find找到要插入的位置,后插入元素。

vector<int> v1;
v1.push_back(1);
v1.push_back(2);
v1.push_back(3);
vector<int>::iterator pos = find(v1.begin(), v1.end(), 2);
//指定位置插入一个值
v1.insert(pos, 6);//1 6 2 3
for (auto e : v1)
{cout << e << " ";
}
//找到元素6,并插入3个8,
v1.insert(find(v1.begin(), v1.end(), 6), 3, 8);//结果为1 8 8 8 6 2 3//找到第一个元素8,并插入一段迭代器区间
vector<char> v2 = { 'a','b','c'};
v1.insert(find(v1.begin(), v1.end(), 8), v2.begin(), v2.end());//结果为1 97 98 99 8 8 8 6 2 3
for (auto e : v1)
{cout << e << " ";
}//删除指定位置的元素
v1.erase(find(v1.begin(), v1.end(), 2));//结果为1 97 98 99 8 8 8 6 2 3//头删
v1.erase(v1.begin());//结果为97 98 99 8 8 8 6 2 3

感谢大家观看,如果大家喜欢,希望大家一键三连支持一下,如有表述不正确,也欢迎大家批评指正。
请添加图片描述

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

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

相关文章

AI语音机器人:通过 Azure Speech 实现类人类的交互

语音对话的重要性 在竞争日益激烈的客户互动领域&#xff0c;人工智能语音对话正成为重中之重。随着数字参与者的崛起&#xff0c;组织认识到语音机器人的强大力量&#xff0c;它是一种自然而直观的沟通方式&#xff0c;可以提供类似人类的体验&#xff0c;深度吸引用户&#…

jmeter中上传文件接口,当文件名为中文时出现乱码

1、在jmeter5.1.1中配置上传文件接口&#xff0c;当上传的文件为中文名称时&#xff0c;文件名称会显示乱码如图 2、解决方案是需要更换jmeter/lib/ext文件中的ApacheJMeter_http.jar 包 3、更换jar包经过多次实验&#xff0c;发现有的上传文件接口中文名正常&#xff0c;但是有…

负载均衡--资源申请说明(三)

1.负载方式&#xff1a;分为四层负载和七层负载 2.负载协议&#xff1a;四层负载为TCP和UDP&#xff0c;七层负载为HTTP和HTTPS 4.负载端口&#xff1a;填写虚地址的端口&#xff08;一般与后端服务端口保持一致&#xff09; 5.真实服务IP&#xff1a;指被负载的后台真实服务…

从零开始:理解并实践Prompt Flow

在人工智能领域中&#xff0c;代码先行与模型紧密结合的Prompt Flow逐渐成为开发者关注的新焦点。今天&#xff0c;我们将共同探索如何快速启动Prompt Flow项目&#xff0c;深入了解流&#xff08;flow&#xff09;的概念&#xff0c;并学习如何使用VS Code Extension或YAML来编…

基于Python的机器学习系列(26):PyTorch中的梯度计算

在本篇中&#xff0c;我们将探讨PyTorch的autograd功能&#xff0c;它为张量操作提供自动微分。我们将学习如何使用torch.autograd工具计算梯度并进行反向传播。 自动微分&#xff08;Autograd&#xff09; PyTorch的autograd包自动计算张量的梯度。当一个张量的.requires_gra…

C++和Python混合编程——C++调用Python入门

大纲 代码结构初始化 Python 解释器获取 GIL为什么需要 GIL&#xff1f;GIL 的影响 导入 Python 模块并执行代码释放 GIL终止 Python 解释器 完整代码编译执行结果项目地址 在《C和Python混合编程——Python调用C入门》一文中&#xff0c;我们熟悉了Python调用C编译的动态库的方…

集成电路学习:什么是PWM脉冲宽度调制

一、PWM&#xff1a;脉冲宽度调制 PWM&#xff0c;全称为脉冲宽度调制&#xff08;Pulse Width Modulation&#xff09;&#xff0c;是一种通过调整脉冲信号的宽度来控制电路输出的技术。在PWM中&#xff0c;信号的输出由一系列等幅值的脉冲组成&#xff0c;这些脉冲的宽度根据…

上海亚商投顾:深成指、创业板指均涨超1%,华为产业链反复活跃

上海亚商投顾前言&#xff1a;无惧大盘涨跌&#xff0c;解密龙虎榜资金&#xff0c;跟踪一线游资和机构资金动向&#xff0c;识别短期热点和强势个股。 一.市场情绪 大小指数昨日走势分化&#xff0c;沪指全天震荡调整&#xff0c;2800点失而复得&#xff0c;深成指、创业板指…

golang

一.go执行流程 4&#xff09;go run运行时间明显要比第一种时间长一点 【3】编译后的文件可以替换名称 二.语法注意 1.源文件以“go”为扩展名 2.程序的执行入口是main&#xff08;&#xff09;函数。 3.严格区分大小写 4.方法由一条条语句构成&#xff0c;每个语句后不需…

Docker安全

Docker安全 和本地共享资源&#xff0c;会有安全性问题 1. Cgroups 对资源的上限进行控制 /sys/devices/system1.1 cpu资源限制 # 进行cpu控制&#xff0c;只使用20%的资源 docker run -it --rm --cpu-period 100000 --cpu-quota 20000 ubuntu# 测试cpu使用 dd if/dev/zer…

【题目全解】蓝桥杯24省赛C++中高级组题干题解

本帖只提供六道编程题的解题思路&#xff0c;部分题目并不提供实际的代码&#xff08;因为我赛时忘记把代码截图下来了&#xff09;。 T1 - 看书 题干描述&#xff1a; 一本书共 n n n 页&#xff0c;小明计划第一天看 x x x 页&#xff0c;此后每一天都要比前一天多看 y y…

【面试八股总结】MySQL 锁:全局锁、表级锁、行级锁

1. 全局锁 顾名思义&#xff0c;全局锁就是对整个数据库实例加锁。 MySQL 提供了⼀个加全局读锁的方法&#xff1a; flush tables with read lock 释放全局锁&#xff0c;执行命令&#xff1a; unlock tables 需要让整个库处于只读状态的时候&#xff0c;可以使用全局锁命…

鸿蒙(API 12 Beta6版)图形【NativeImage开发指导 (C/C++)】方舟2D图形服务

场景介绍 NativeImage是提供Surface关联OpenGL外部纹理的模块&#xff0c;表示图形队列的消费者端。开发者可以通过NativeImage接口接收和使用Buffer&#xff0c;并将Buffer关联输出到OpenGL外部纹理。 针对NativeImage&#xff0c;常见的开发场景如下&#xff1a; 通过Nati…

linux系统中USB模块鼠标驱动实现

各位开发者大家好,今天主要给大家分享一下,Linux系统中使用libusb的方法以及鼠标驱动实现。 第一:libusb概述 参考网址:* libusb GIT仓库:https://github.com/libusb/libusb.git * libusb 官网:https://libusb.info/ * libusb API接口:https://libusb.sourceforge.io/…

mysql 使用 general 开启SQL跟踪功能

查看当前状态 mysql> SHOW VARIABLES LIKE %general%; 启用 临时启用 SET GLOBAL general_logon; SET GLOBAL general_log_file/tmp/general.log; 永久启用 通过修改配置文件来启用,需要重启mysql服务 [mysqld] general_logON general_log_file/tmp/general.log 再次查看状态…

【Redis】Redis 持久化机制详解:RDB、AOF 和混合持久化的工作原理及优劣分析

目录 持久化RDB触发机制流程说明RDB ⽂件的处理RDB 的优缺点 AOF使⽤ AOF命令写⼊⽂件同步重写机制启动时数据恢复 混合持久化小结 持久化 回顾 MySQL 的事务的特性&#xff1a; 原子性一致性持久性&#xff08;持久化&#xff09;隔离性 持久化&#xff1a;把数据存储在硬盘上…

CAN总线之一篇文章讲清楚Motorala和inter格式

前言&#xff1a; 之前的工作中&#xff0c;其实对Motorala和inter格式并不是了解的十分透彻。最近由于工作需要&#xff0c;研究了一下这两种格式&#xff0c;发现里面的门道其实挺复杂的。 特此作了一些总结&#xff1a;和大家一起分享。 我查了不少文档&#xff0c;描述其…

MongoDB 向 PostgreSQL 宣战

上周 MongoDB 发布了一份亮眼的季度财报&#xff0c;盘后股价涨幅超过 18%。 值得一提的是&#xff0c;MongoDB 的 CEO Dev Ittycheria 特别提到 MongoDB 正在借助自己的数据库服务 Atlas 从 PostgreSQL 那里挖角。原话是举了一个博彩网站的例子&#xff1a; “Initially, th…

【C++ 第十八章】C++11 新增语法(4)

前情回顾&#xff1a; 【C11 新增语法&#xff08;1&#xff09;&#xff1a;1~6 点】 C11出现与历史、花括号统一初始化、initializer_list初始化列表、 auto、decltype、nullptr、STL的一些新变化 【C11 新增语法&#xff08;2&#xff09;&#xff1a;7~8 点】 右值引用和…

uniapp插槽用法

目录 什么是插槽? 基本概念 默认插槽 命名插槽 作用域插槽 场景一:子插槽向父组件传递一个字符串 场景二:子插槽向父组件传递对象 什么是插槽? 在 UniApp 中&#xff0c;插槽&#xff08;Slot&#xff09;是一种允许父组件向子组件特定位置插入HTML内容的方式。这种方式使得组…