C++详解vector
目录
构造和拷贝构造
赋值运算符重载:
vector的编辑函数:
assign函数:
push_back和pop_back函数:
insert函数:
erase函数:
swap函数:
clear函数:
begin函数:
end函数:
rbegin函数:
size函数:
resize函数:
capacity函数:
reserve函数:
operator【】重载:
vector库是一个动态数组库,相比于string库,vector就显得没那么冗余,vector翻译为:向量。也就是一个方向的动态延长,所以可以抽象的理解为数组,这也跟C语言中数组的作用一样,只不过C语言中的数组arr【】是静态数组(需要自己手动来进行开空间、拷贝数据、释放空间),vector是动态数组(无需自己进行复杂的开空间跟释放空间)。
直接来使用vector:
创建一个vector:
格式:vector<所存的数据类型> 类名称
构造和拷贝构造
#include<iostream>
#include<vector>
using namespace std;
int main() {//最原始的构造,构造一个空vectorvector<int> v1;//构造可以指定初始化的内容和大小vector<int> v2(3, 10);//构造一段迭代器区间vector<int> v3(v2.begin(), v2.end());//拷贝构造vector<int> v4(v3);return 0;
}
赋值运算符重载
作用:将vector赋值给另一个vector
#include<iostream>
#include<vector>
using namespace std;
int main() {//创建大小为3初始值为1的v1vector<int> v1(3, 1);//创建大小为5初始值为2的v2vector<int> v2(5, 2);//打印v1,v2for (auto e : v1) {cout << e << " ";}cout << endl;for (auto e : v2) {cout << e << " ";}cout << endl;//赋值v2 = v1;//重新打印v1,v2for (auto e : v1) {cout << e << " ";}cout << endl;for (auto e : v2) {cout << e << " ";}return 0;
}
v2的大小和内容已经被调整为v1的大小和内容了
vector的编辑函数:
assign函数:
作用:分配给vector一段新内容
#include<iostream>
#include<vector>
using namespace std;
int main() {vector<int> v1;vector<int> v2;vector<int> v3;//分配给当前vector指定大小的指定值v1.assign(5, 10);//分配给当前vector一段迭代器区间vector<int>::iterator it1 = v1.begin();v2.assign(it1 + 1, v1.end() - 1);//分配给当前vector数组的一段区间int arr[] = { 1,2,3 };v3.assign(arr, arr + 3);cout << "size of v1: " << v1.size() << endl;cout << "size of v2: " << v2.size() << endl;cout << "size of v3: " << v3.size() << endl;return 0;
}
push_back和pop_back函数:
作用:尾插和尾删我们的老朋友了,不再过多介绍,用法也是很简单,看个代码自行感悟一下吧
#include<iostream>
#include<vector>
using namespace std;
int main() {vector<int> v1;//尾插1,2,3,4v1.push_back(1);v1.push_back(2);v1.push_back(3);v1.push_back(4);//打印1 2 3 4for (auto e : v1) {cout << e << " ";}cout << endl;//尾删最后的两个元素v1.pop_back();v1.pop_back();//打印1 2for (auto e : v1) {cout << e << " ";}return 0;
}
insert函数:
作用:插入一个值或者插入多个值或者一段迭代器区间
#include<iostream>
#include<vector>
using namespace std;
int main() {vector<int> v1;//原始数据1234567v1.push_back(1);v1.push_back(2);v1.push_back(3);v1.push_back(4);v1.push_back(5);v1.push_back(6);v1.push_back(7);//最开始的后面两个位置处,插入30v1.insert(v1.begin() + 2, 30);for (auto e : v1) {cout << e << " ";}cout << endl;//最开始的后面两个位置处,插入3个30v1.insert(v1.begin() + 2, 3, 30);for (auto e : v1) {cout << e << " ";}cout << endl;//最开始的后面两个位置处,插入3个10int arr[] = { 10,10,10 };v1.insert(v1.begin() + 2, arr, arr + 3);for (auto e : v1) {cout << e << " ";}cout << endl;return 0;
}
erase函数:
作用:删除一个元素或者一段区间。
#include<iostream>
#include<vector>
using namespace std;
int main() {vector<int> v1;//插入十个元素for (int i = 1; i <= 10; i++) {v1.push_back(i);}for (auto e : v1) {cout << e << " ";}cout << endl;//删除一个元素,从第一个位置开始往后数五个位置,也就是第六个位置v1.erase(v1.begin() + 5);for (auto e : v1) {cout << e << " ";}cout << endl;//删除一段区间,从第一个位置到第三个位置的区间v1.erase(v1.begin(), v1.begin() + 3);for (auto e : v1) {cout << e << " ";}return 0;
}
swap函数:
作用:交换两个vector
#include<iostream>
#include<vector>
using namespace std;
int main() {vector<int> v1(3, 100);//大小为3vector<int> v2(5, 200);//大小为5for (auto e : v1) {cout << e << " ";}cout << endl;for (auto e : v2) {cout << e << " ";}cout << endl;swap(v1, v2);//交换两个vectorfor (auto e : v1) {cout << e << " ";}cout << endl;for (auto e : v2) {cout << e << " ";}return 0;
}
clear函数:
作用:将vector中的所有内容给清空。
#include<iostream>
#include<vector>
using namespace std;
int main() {vector<int> v1(3, 100);//大小为3for (auto e : v1) {cout << e << " ";}cout << endl;v1.clear();for (auto e : v1) {cout << e << " ";}return 0;
}
begin函数:
作用:返回起始位置的迭代器
end函数:
作用:返回结尾位置的迭代器
#include<iostream>
#include<vector>
using namespace std;
int main() {vector<int> v1;//插入十个数据for (int i = 1; i <= 10; i++) {v1.push_back(i);}vector<int>::iterator it1 = v1.begin();for (; it1 != v1.end(); it1++) {cout << *it1 << " ";}cout << endl;return 0;
}
rbegin函数:
作用:返回指向vector容器起始元素的反向迭代器
作用:返回指向vector容器末尾元素的反向迭代器
#include<iostream>
#include<vector>
using namespace std;
int main() {vector<int> v1;//插入十个数据for (int i = 1; i <= 10; i++) {v1.push_back(i);}//打印for (auto e : v1) {cout << e << " ";}cout << endl;//反转迭代器vector<int>::reverse_iterator it1 = v1.rbegin();//打印for (; it1 != v1.rend(); it1++) {cout << *it1 << " ";}return 0;
}
size函数:
作用:返回vector的大小
#include<iostream>
#include<vector>
using namespace std;
int main() {vector<int> v1;//插入十个数据for (int i = 1; i <= 10; i++) {v1.push_back(i);}cout << v1.size() << endl;return 0;
}
resize函数:
作用:当n小于vector的size大小的时候,缩容(将超出n以外的元素给删掉,将大小更新为n)
当n大于vector的size大小的时候,扩容(将大小更新为n,用val来补充扩充的地方,如果没给val,就用0补充扩充的元素)
#include<iostream>
#include<vector>
using namespace std;
int main() {vector<int> v1;//将大小扩充为5,以0初始化v1.resize(5);//将大小扩充为8,以100初始化v1.resize(8, 100);//将大小缩容为3v1.resize(3);return 0;
}
capacity函数:
作用: 返回vector的capacity
#include<iostream>
#include<vector>
using namespace std;
int main() {vector<int> v1;for (int i = 1; i < 100; i++) {v1.push_back(i);}cout << v1.capacity() << endl;return 0;
}
reserve函数:
作用:手动扩容,当我们知道我们需要开多大空间的时候,就可以进行手动扩容,可以使得编译器多次扩容浪费时间
#include<iostream>
#include<vector>
using namespace std;
int main() {vector<int> v1;for (int i = 1; i < 10; i++) {//每次插入五个数据v1.push_back(i);v1.push_back(i);v1.push_back(i);v1.push_back(i);v1.push_back(i);cout << "capacity:" << v1.capacity() << endl;}cout << endl;vector<int> v2;//手动扩容v2.reserve(50);for (int i = 1; i < 10; i++) {//每次插入五个数据v2.push_back(i);v2.push_back(i);v2.push_back(i);v2.push_back(i);v2.push_back(i);cout << "capacity:" << v2.capacity() << endl;}return 0;
}
operator【】重载:
作用:访问vector中的元素
#include<iostream>
#include<vector>
using namespace std;
int main() {vector<int> v1;for (int i = 1; i < 10; i++) {v1.push_back(i);}cout << v1[3] << endl;return 0;
}
我们先就介绍vector这些最常见的用法,感谢大家观看!
相关文章:

C++详解vector
目录 构造和拷贝构造 赋值运算符重载: vector的编辑函数: assign函数: push_back和pop_back函数: insert函数: erase函数: swap函数: clear函数: begin函数: e…...

Redis实战--Redis的数据持久化与搭建Redis主从复制模式和搭建Redis的哨兵模式
Redis作为一个高性能的key-value数据库,广泛应用于缓存、消息队列、排行榜等场景。然而,Redis是基于内存的数据库,这意味着一旦服务器宕机,内存中的数据就会丢失。为了解决这个问题,Redis提供了数据持久化的机制&#…...

World of Warcraft [CLASSIC] Engineering 421-440
工程学421-440 World of Warcraft [CLASSIC] Engineering 335-420_魔兽世界宗师级工程学需要多少点-CSDN博客 【萨隆邪铁锭】421-425 学习新技能,其他都不划算,只能做太阳瞄准镜 【太阳瞄准镜】426、427、428、429 【随身邮箱】430 这个基本要做的&am…...
VUE3.5版本解读
官网:Announcing Vue 3.5 | The Vue Point 2024年9月1日,宣布 Vue 3.5“天元突破:红莲螺岩”发布! 反应系统优化 在 3.5 中,Vue 的反应系统经历了另一次重大重构,在行为没有变化的情况下实现了更好的性能…...

spark计算引擎-架构和应用
一Spark 定义:Spark 是一个开源的分布式计算系统,它提供了一个快速且通用的集群计算平台。Spark 被设计用来处理大规模数据集,并且支持多种数据处理任务,包括批处理、交互式查询、机器学习、图形处理和流处理。 核心架构&#x…...
VUE 开发——AJAX学习(二)
一、Bootstrap弹框 功能:不离开当前页面,显示单独内容,供用户操作 步骤: 引入bootstrap.css和bootstrap.js准备弹框标签,确认结构通过自定义属性,控制弹框显示和隐藏 在<head>部分添加:…...

机器学习-KNN分类算法
1.1 KNN分类 KNN分类算法(K-Nearest-Neighbors Classification),又叫K近邻算法。它是概念极其简单,而效果又很优秀的分类算法。1967年由Cover T和Hart P提出。 KNN分类算法的核心思想:如果一个样本在特征空间中的k个最…...

云计算 Cloud Computing
文章目录 1、云计算2、背景3、云计算的特点4、云计算的类型:按提供的服务划分5、云计算的类型:按部署的形式划分 1、云计算 定义: 云计算是一种按使用量付费的模式,这种模式提供可用的、便捷的、按需的网络访问,进入可…...

【算法】DFS 系列之 穷举/暴搜/深搜/回溯/剪枝(上篇)
【ps】本篇有 9 道 leetcode OJ。 目录 一、算法简介 二、相关例题 1)全排列 .1- 题目解析 .2- 代码编写 2)子集 .1- 题目解析 .2- 代码编写 3)找出所有子集的异或总和再求和 .1- 题目解析 .2- 代码编写 4)全排列 II…...

怎么绕开华为纯净模式安装软件
我是标题 众所周不知,华为鸿蒙系统自带纯净模式,而且 没法关闭 : ) 我反正没找到关闭键 以前或许会有提示,无视风险,“仍要安装”。但我这次遇到的问题是,根本没有这个选项,只有“应用市场”和“取消”&…...

CentOS7 离线部署docker和docker-compose环境
一、Docker 离线安装 1. 下载docker tar.gz包 下载地址: Index of linux/static/stable/x86_64/ 本文选择版本:23.0.6 2.创建docker.service文件 vi docker.service文件内容如下: [Unit] DescriptionDocker Application Container Engi…...

Vue 自定义组件实现 v-model 的几种方式
前言 在 Vue 中,v-model 是一个常用的指令,用于实现表单元素和组件之间的双向绑定。当我们使用原生的表单元素时,直接使用 v-model 是很方便的,但是对于自定义组件来说,要实现类似的双向绑定功能就需要一些额外的处理…...
Python Pandas数据处理效率提升指南
大家好,在数据分析中Pandas是Python中最常用的库之一,然而当处理大规模数据集时,Pandas的性能可能会受到限制,导致数据处理变得缓慢。为了提升Pandas的处理速度,可以采用多种优化策略,如数据类型优化、向量…...

最大正方形 Python题解
最大正方形 题目描述 在一个 n m n\times m nm 的只包含 0 0 0 和 1 1 1 的矩阵里找出一个不包含 0 0 0 的最大正方形,输出边长。 输入格式 输入文件第一行为两个整数 n , m ( 1 ≤ n , m ≤ 100 ) n,m(1\leq n,m\leq 100) n,m(1≤n,m≤100),接…...
ubuntu中软件的进程管理-结束软件运行
在Ubuntu系统中,当某个运行中的软件无法正常退出时,可以通过以下几种方法强制结束该软件: 方法一:使用系统监视器(System Monitor)–小白专属 这个相当于win上的资源管理器 打开系统监视器 可以通过点击屏…...

Windows环境部署Oracle 11g
Windows环境部署Oracle 11g 1.安装包下载2. 解压安装包3. 数据库安装3.1 执行安装脚本3.2 电子邮件设置3.3 配置安装选项3.4 配置系统类3.5 选择数据库安装类型3.6 选择安装类型3.7 数据库配置3.8 确认安装信息3.9 设置口令 Oracle常用命令 2023年10月中旬就弄出大致的文章&…...

C语言进阶【8】--联合体和枚举(联合体和枚举这么好用,你不想了解一下吗?)
本章概述 联合体类型的声明联合体的特点联合体的大小的计算枚举类型的声明枚举类型的优点枚举类型的使用枚举类型的大小彩蛋时刻!!! 联合体类型的声明 概述:联合体的关键字为 union。它的结构和结构体是一样的。进行展示…...

Android OTA升级
针对Android系统OTA升级,MTK平台有相关介绍文档:https://online.mediatek.com/apps/faq/detail?faqidFAQ27117&listSW 概念一:OTA包的构建 AOSP full build:Android原生提供的全量包的构建,意思就是可以从任何一…...

【项目经验分享】深度学习自然语言处理技术毕业设计项目案例定制
以下毕业设计是与深度学习自然语言处理(NLP)相关的毕业设计项目案例,涵盖文本分类、生成式模型、语义理解、机器翻译、对话系统、情感分析等多个领域: 实现案例截图: 基于深度学习的文本分类系统基于BERT的情感分析系…...

一觉醒来,YOLO11 冷不丁就来了
🥇 版权: 本文由【墨理学AI】原创首发、各位读者大大、敬请查阅、感谢三连 🎉 声明: 作为全网 AI 领域 干货最多的博主之一,❤️ 不负光阴不负卿 ❤️ 文章目录 前言:一觉醒来,YOLO11 冷不丁就来了ultralytics 版本更新…...

深入剖析AI大模型:大模型时代的 Prompt 工程全解析
今天聊的内容,我认为是AI开发里面非常重要的内容。它在AI开发里无处不在,当你对 AI 助手说 "用李白的风格写一首关于人工智能的诗",或者让翻译模型 "将这段合同翻译成商务日语" 时,输入的这句话就是 Prompt。…...
java调用dll出现unsatisfiedLinkError以及JNA和JNI的区别
UnsatisfiedLinkError 在对接硬件设备中,我们会遇到使用 java 调用 dll文件 的情况,此时大概率出现UnsatisfiedLinkError链接错误,原因可能有如下几种 类名错误包名错误方法名参数错误使用 JNI 协议调用,结果 dll 未实现 JNI 协…...
汇编常见指令
汇编常见指令 一、数据传送指令 指令功能示例说明MOV数据传送MOV EAX, 10将立即数 10 送入 EAXMOV [EBX], EAX将 EAX 值存入 EBX 指向的内存LEA加载有效地址LEA EAX, [EBX4]将 EBX4 的地址存入 EAX(不访问内存)XCHG交换数据XCHG EAX, EBX交换 EAX 和 EB…...

pikachu靶场通关笔记22-1 SQL注入05-1-insert注入(报错法)
目录 一、SQL注入 二、insert注入 三、报错型注入 四、updatexml函数 五、源码审计 六、insert渗透实战 1、渗透准备 2、获取数据库名database 3、获取表名table 4、获取列名column 5、获取字段 本系列为通过《pikachu靶场通关笔记》的SQL注入关卡(共10关࿰…...

GC1808高性能24位立体声音频ADC芯片解析
1. 芯片概述 GC1808是一款24位立体声音频模数转换器(ADC),支持8kHz~96kHz采样率,集成Δ-Σ调制器、数字抗混叠滤波器和高通滤波器,适用于高保真音频采集场景。 2. 核心特性 高精度:24位分辨率,…...
基于Java Swing的电子通讯录设计与实现:附系统托盘功能代码详解
JAVASQL电子通讯录带系统托盘 一、系统概述 本电子通讯录系统采用Java Swing开发桌面应用,结合SQLite数据库实现联系人管理功能,并集成系统托盘功能提升用户体验。系统支持联系人的增删改查、分组管理、搜索过滤等功能,同时可以最小化到系统…...
CSS | transition 和 transform的用处和区别
省流总结: transform用于变换/变形,transition是动画控制器 transform 用来对元素进行变形,常见的操作如下,它是立即生效的样式变形属性。 旋转 rotate(角度deg)、平移 translateX(像素px)、缩放 scale(倍数)、倾斜 skewX(角度…...
Vite中定义@软链接
在webpack中可以直接通过符号表示src路径,但是vite中默认不可以。 如何实现: vite中提供了resolve.alias:通过别名在指向一个具体的路径 在vite.config.js中 import { join } from pathexport default defineConfig({plugins: [vue()],//…...
【学习笔记】erase 删除顺序迭代器后迭代器失效的解决方案
目录 使用 erase 返回值继续迭代使用索引进行遍历 我们知道类似 vector 的顺序迭代器被删除后,迭代器会失效,因为顺序迭代器在内存中是连续存储的,元素删除后,后续元素会前移。 但一些场景中,我们又需要在执行删除操作…...

实战三:开发网页端界面完成黑白视频转为彩色视频
一、需求描述 设计一个简单的视频上色应用,用户可以通过网页界面上传黑白视频,系统会自动将其转换为彩色视频。整个过程对用户来说非常简单直观,不需要了解技术细节。 效果图 二、实现思路 总体思路: 用户通过Gradio界面上…...