【C++】STL——vector的使用

news/2025/3/14 0:52:04/

目录

💕1.vector介绍

💕2.vector的基本用法 

💕3.vector功能的具体用法 (讲解)

💕4.vector——size,capacity函数的使用 (简单略讲)

💕5.resize,reserve函数 

💕6.empty函数 

💕7.front函数,back函数,operator[ ]函数 

💕8.push_back函数,pop_back函数 

💕9.begin函数,end函数 

💕10.rbegin函数,rend函数 

💕11.insert函数,erase函数

💕12.sort函数对vector排序 

💕13.完结


独帜入渊深未知  身似浮萍命难持

(最新更新时间——2025.2.4)

 

💕1.vector介绍

vector 是 C++ 标准模板库(STL)中提供的动态数组容器,能够自动管理内存,支持高效的元素访问和在尾部快速增删元素。与普通数组相比,vector 的大小可以动态调整,是 C++ 中最常用的容器之一。

💕2.vector的基本用法 

vector 的使用需要包含一个头文件

#include<vector>

vector 中有许多我们常见的操作,如下->:


迭代器功能->:

其他功能:

💕3.vector功能的具体用法 (讲解)

接下来会讲解vector中最常用的几种函数用法,先讲解vector的初始化


vector在创建时因为模板的作用,可以指定vector的内容类型,如下->:

#define _CRT_SECURE_NO_WARNINGS 
#include<vector>
#include<string>
#include<iostream>
using namespace std;
int main()
{vector<int> a1 = { 1,2,3 };vector<double> a2 = { 2 };vector<string> a3 = { "hello","world" };vector<char> s1 = { 'c' };vector<int> b1(2);//也可以如下初始化,但不推荐vector<int> b2(2,3);
}

可以指定是int,double,char或者string类型

💕4.vector——size,capacity函数的使用 (简单略讲)

size函数用来返回顺序表(vector)中的有效值

capacity用来返回顺序表(vector)中的容量

maxsize用来表示顺序表(vector)的最大有效值是多少


代码如下->:

#define _CRT_SECURE_NO_WARNINGS 
#include<vector>
#include<string>
#include<iostream>
using namespace std;
int main()
{vector<int> a1 = { 1,2,3,4 };cout << a1.size()<<endl;//打印4cout << a1.capacity() << endl;//打印4cout << a1.max_size() << endl;//打印一个巨大的数
}

💕5.resize,reserve函数 

resize函数可以更改顺序表中的有效值(size)个数,并且如果更改后的size个数大于原size个数,可以将新开辟的size初始化一个值(注意是可以,不是一定,需要用户显示写)


我们用代码为例

可以看到,我们更改了size的个数,接下来进行别的测试


这次,我们更改后的size个数比原来的size大,我们显示的将新开辟的size全部初始化为9,注意一定是新开辟的size初始化,如果我们更改后的size比原来的小是不会有作用的,如下:


接下来: reserve 函数是用来更改顺序表中的capacity大小的,它被称为预留空间,它只会扩大capacity,并不会缩小capacity,并且不会将新开辟的capacity初始化,我们以代码为例


这里的遍历顺序表没有意义,不用在意

💕6.empty函数 

empty函数用来判断顺序表是否为空,它返回的值是bool类型

💕7.front函数,back函数,operator[ ]函数 

front函数用来返回顺序表的第一个有效值

back函数用来返回顺序表的最后一个有效值

operator[ ]供我们可以用下标访问顺序表中的内容


代码如下->:

💕8.push_back函数,pop_back函数 

push_back用来实现顺序表的尾插


pop_back用来实现顺序表的尾删


代码如下->:


💕9.begin函数,end函数 

begin函数与end函数都为迭代器类型,我们可以把它理解为指针一样的东西

begin()返回的是顺序表的首地址,end()返回的是顺序表中最后一个元素的下一个位置


虽然它们的返回类型不是指针,但我们可以像使用指针一样使用它


可以理解为指针一样的存在,但是并不是指针


用它们我们可以实现遍历

💕10.rbegin函数,rend函数 

rbegin函数与rend函数一样都是迭代器类型,并且依旧可以像指针一样使用

只不过rbegin与rend所指的位置调过来了

rbegin函数返回的是顺序表中最后一个元素的下一个位置

rend()返回的是顺序表的首地址


rbegin的++被重载了,也就是说rbegin函数的++实际上是我们正常使用的--,而rbegin的--实际上就是我们正常使用的++

rend同理

💕11.insert函数,erase函数

 insert函数用来实现在某一位置插入数据

erase函数用来实现在某一位置删除数据,也可以全部删除


这里需要特别注意,insert与erase函数所指的位置,并不是我们常用的下标,而是迭代器返回的位置,我们先看代码->:


💕12.sort函数对vector排序 

我们如果想对vector函数排序,可以使用std里面的sort函数排序,并且可以选择升序或者降序,示例如下->:需要注意的是sort函数需要的是迭代器类型


默认是升序的结果,如果想要降序就要用到一个函数,并添加到sort函数里

 std::greater<int>()

如何使用?

 

这样就变为降序了

💕13.完结


http://www.ppmy.cn/news/1569557.html

相关文章

【JavaEE】Spring(6):Mybatis(下)

一、Mybatis XML配置文件 Mybatis开发有两种方式&#xff1a; 注解XML 之前讲解了注解的方式&#xff0c;接下来学习XML的方式 1.1 配置数据库连接和Mybatis 直接在配置文件中配置即可&#xff1a; spring:datasource:url: jdbc:mysql://127.0.0.1:3306/mybatis_test?cha…

基序和纯度分数的计算

以下对这两个概念的详细解释&#xff1a; 基序 纯度分数 PWM矩阵的来源 为什么会有PWM矩阵&#xff1f; 一个特定的转录因子&#xff08;TF&#xff09;的结合位点的基序&#xff08;motif&#xff09;并不是唯一的。实际上&#xff0c;TF结合位点通常具有一定的序列变异性&a…

高阶开发基础——快速入门C++并发编程6——大作业:实现一个超级迷你的线程池

目录 实现一个无返回的线程池 完全代码实现 Reference 实现一个无返回的线程池 实现一个简单的线程池非常简单&#xff0c;我们首先聊一聊线程池的定义&#xff1a; 线程池&#xff08;Thread Pool&#xff09; 是一种并发编程的设计模式&#xff0c;用于管理和复用多个线程…

jEasyUI 转换 HTML 表格为数据网格

jEasyUI 转换 HTML 表格为数据网格 引言 随着互联网技术的飞速发展,前端框架和库的应用越来越广泛。jEasyUI 是一款功能强大的 jQuery UI 扩展库,它提供了丰富的 UI 组件,其中数据网格(DataGrid)是 jEasyUI 中一个非常重要的组件。本文将详细介绍如何使用 jEasyUI 将一个…

ASP.NET Core与配置系统的集成

目录 配置系统 默认添加的配置提供者 加载命令行中的配置。 运行环境 读取方法 User Secrets 注意事项 Zack.AnyDBConfigProvider 案例 配置系统 默认添加的配置提供者 加载现有的IConfiguration。加载项目根目录下的appsettings.json。加载项目根目录下的appsettin…

对顾客行为的数据分析:融入2+1链动模式、AI智能名片与S2B2C商城小程序的新视角

摘要&#xff1a;随着互联网技术的飞速发展&#xff0c;企业与顾客之间的交互方式变得日益多样化&#xff0c;移动设备、社交媒体、门店、电子商务网站等交互点应运而生。这些交互点不仅为顾客提供了便捷的服务体验&#xff0c;同时也为企业积累了大量的顾客行为数据。本文旨在…

React第二十七章(Suspense)

Suspense Suspense 是一种异步渲染机制&#xff0c;其核心理念是在组件加载或数据获取过程中&#xff0c;先展示一个占位符&#xff08;loading state&#xff09;&#xff0c;从而实现更自然流畅的用户界面更新体验。 应用场景 异步组件加载&#xff1a;通过代码分包实现组件…

【Java-数据结构】Java 链表面试题下 “最后一公里”:解决复杂链表问题的致胜法宝

我的个人主页 我的专栏&#xff1a;Java-数据结构&#xff0c;希望能帮助到大家&#xff01;&#xff01;&#xff01;点赞❤ 收藏❤ 引言&#xff1a; Java链表&#xff0c;看似简单的链式结构&#xff0c;却蕴含着诸多有趣的特性与奥秘&#xff0c;等待我们去挖掘。它就像一…