vector容器以及deque

news2025/3/20 12:00:52

vector

  • 一.vector容器简介
  • 二.vector的默认构造
    • 1. 语法和功能
    • 2.vector带参数的构造
    • 3.vector的赋值
    • 4.vector的大小
    • 5.vector数值操作
  • deque简介:

一.vector容器简介

• vector是将元素置于一个动态数组中加以管理的容器。
std::vector 是 C++ 标准模板库(STL)中的一个动态数组容器,它能在运行时动态调整大小,提供了高效的随机访问能力。
使用 std::vector 之前,需要包含 vector 头文件:

#include <vector》

二.vector的默认构造

1. 语法和功能

std::vector 的默认构造函数用于创建一个空的 vector 容器,即该容器不包含任何元素。其语法形式如下:

std::vector<Type> vec;

vector<T> vecT; 
vector<int> vecInt; //一个存放int的vector容器。 
vector<float> vecFloat; //一个存放float的vector容器。 
vector<string> vecString; //一个存放string的vector容器。
.......            //尖括号内还可以设置指针类型或自定义类型。

这里的 Type 是 vector 所存储元素的类型,vec 是创建的 vector 对象的名称。默认构造函数创建的 vector 初始容量为 0,当向其中添加元素时,它会根据需要自动分配内存。

默认构造函数的作用
创建空向量:默认构造函数会创建一个没有任何元素的向量,其 size() 方法返回 0。
动态内存分配:虽然向量是空的,但内部可能已经分配了一定的内存(容量),以便后续添加元素时不需要频繁重新分配内存。

2.vector带参数的构造

  1. vector(beg,end);
    //构造函数将[beg, end)区间中的元素拷贝给本身。注意该区间是左闭右开的区间。
    要注意左闭右开

  2. vector(n,elem);
    //构造函数将n个elem拷贝给本身。

  3. vector(const vector &vec);
    //拷贝构造函数

int* arr[] = {1,2,3,4,5};
 
 vector<int> vecIntA(arr,arr+5) //由于是左闭右开,所以这里end要指向尾元素后一个地址
 
vector<int> vecIntB(vecIntA.begin() , vecIntA.end()); 
vector<int>vecIntB(vecIntA.begin() , vecIntA.begin()+3);
vector<int> vecIntC(3,9); //此代码运行后,容器vecIntB就存放3个元素,每个元素的值是9。 
vector<int> vecIntD(vecIntA);

3.vector的赋值

  1. vector.assign(beg,end);
    //将[beg, end)区间中的数据拷贝赋值给本身。注意该区间是左闭右开的区间。
  2. vector.assign(n,elem);
    //将n个elem拷贝赋值给本身。
  3. vector& operator=(const vector &vec);
    //重载等号操作符
  4. vector.swap(vec);
    // 将vec与本身的元素互换。
  5. std::vector new_vector = std::move(vector_to_move);
    // 使用移动构造函数
    移动构造函数用于将一个向量的内容“移动”到另一个向量中,而不是复制。这种方式效率更高,因为它避免了不必要的复制操作。
int* arr[] = {1,2,3,4,5};
vector<int> vecIntA, vecIntB, vecIntC, vecIntD;
vecIntA.assign(arr,arr+5); //用其它容器的迭代器作参数。
vecIntB.assign(vecIntA.begin(), vecIntA.end());
vecIntC.assign(3,9);
vector<int> vecIntD;
vecIntD = vecIntA; vecIntA.swap(vecIntD);
std::vector<int> vecIntA = std::move(vecIntB);

4.vector的大小

  1. vector.size();
    //返回容器中元素的个数
  2. vector.empty();
    //判断容器是否为空
  3. vector.capacity()
    //返回容器的容量大小
  4. vector.resize(num);
    //重新指定容器的长度为num,若容器变长,则以默认值填充新位置。如果容器变短,则末尾超出容器长度的元素被删除。
  5. vector.resize(num, elem);
    //重新指定容器的长度为num,若容器变长,则以elem值填充新位置。如果容器变短,则末尾超出容器长度的元素被删除。
  6. vector.reserve()
    //reserve 是 std::vector 的成员函数,用于预先分配内存,以避免多次内存重新分配。
  7. vector.clear();
    //用于清空向量中的所有元素,但不会释放内存。clear 会将向量的大小(size)设置为 0,但不会改变容量(capacity)。
    清空后,向量仍然可以继续使用,且不需要重新分配内存

5.vector数值操作

  1. vector.at(idx);
    //返回索引idx所指的数据,如果idx越界,抛出out_of_range异常。
  2. vector[idx];
    //返回索引idx所指的数据,越界时,运行直接报错
  3. vector.push_back();
    //用于在向量的末尾添加一个元素。
  4. vector.pop_back();
    //用于移除向量末尾的元素。
  5. vector.insert(pos,elem);
    //在pos位置插入一个elem元素的拷贝,返回新数据的位置。
    vector.insert(pos,n,elem);
    //在pos位置插入n个elem数据,无返回值。
    vector.insert(pos,beg,end);
    //在pos位置插入[beg,end)区间的数据,无返回值
  6. vector.clear();
    //移除容器的所有数据
    vec.erase(beg,end);
    //删除[beg,end)区间的数据,返回下一个数据的位置。
    vec.erase(pos);
    //删除pos位置的数据,返回下一个数据的位置。

deque简介:

  1. deque是“double-ended queue”的缩写,和vector一样都是STL的容器,deque是双端数组,而vector是单端的。
  2. deque在接口上和vector非常相似,在许多操作的地方可以直接替换。
  3. deque可以随机存取元素(支持索引值直接存取, 用[]操作符或at()方法,
  4. deque头部和尾部添加或移除元素都非常快速。但是在中部安插元素或移除元素比较费时。

deque与vector在操作上几乎一样,deque多两个函数:

deque.push_front(elem); //在容器头部插入一个数据
deque.pop_front(); //删除容器第一个数据

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

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

相关文章

Java SE 面经

1、Java 语言有哪些特点 Java 语言的特点有&#xff1a; ①、面向对象。主要是&#xff1a;封装&#xff0c;继承&#xff0c;多态。 ②、平台无关性。一次编写&#xff0c;到处运行&#xff0c;因此采用 Java 语言编写的程序具有很好的可移植性。 ③、支持多线程。C 语言没…

关于redis中的分布式锁

目录 分布式锁的基础实现 引入过期时间 引入校验id 引入lua脚本 引入看门狗 redlock算法 分布式锁的基础实现 多个线程并发执行的时候&#xff0c;执行的先后顺序是不确定的&#xff0c;需要保证程序在任意执行顺序下&#xff0c;执行逻辑都是ok的。 在分布式系统中&am…

Python实战(2)-数据库支持

使用简单的纯文本文件可实现的功能有限。诚然&#xff0c;使用它们可做很多事情&#xff0c;但有时可能还需要额外的功能。你可能希望能够自动完成序列化&#xff0c;此时可求助于shelve和pickle&#xff08;类似于shelve&#xff09;​。不过你可能需要比这更强大的功能。例如…

从 Snowflake 到 Databend Cloud:全球游戏平台借助 Databend 实现实时数据处理

导读&#xff1a;某全球游戏平台为全球数百万玩家提供实时的技能型游戏体验与无缝的实时互动。对该游戏平台而言&#xff0c;保持数据的实时更新和实时分析&#xff0c;对提升玩家互动和留存率至关重要。他们在使用 Snowflake 进行实时数据摄取和分析时遇到了重大挑战&#xff…

Docker搭建MySQL主从服务器

一、在主机上创建MySQL配置文件——my.cnf master服务器配置文件路径&#xff1a;/data/docker/containers/mysql-cluster-master/conf.d/my.cnf slave服务器配置文件路径&#xff1a; /data/docker/containers/mysql-cluster-master/conf.d/my.cnf master服务配置文件内容 …

C语言每日一练——day_12(最后一天)

引言 针对初学者&#xff0c;每日练习几个题&#xff0c;快速上手C语言。第十二天。&#xff08;最后一天&#xff0c;完结散花啦&#xff09; 采用在线OJ的形式 什么是在线OJ&#xff1f; 在线判题系统&#xff08;英语&#xff1a;Online Judge&#xff0c;缩写OJ&#xff0…

10、STL中的unordered_map使用方法

一、了解 1、unordered_map(哈希) unordered_map是借用哈希表实现的关联容器。 访问键值对O&#xff08;1&#xff09;&#xff0c;最坏情况O&#xff08;n&#xff09;&#xff0c;例如哈希冲突严重时。【n是一个哈希桶的元素数量】 unordered_map特性 键值对存储&#xff…

本地部署deepseek-r1建立向量知识库和知识库检索实践【代码】

目录 一、本地部署DS 二、建立本地知识库 1.安装python和必要的库 2.设置主目录工作区 3.编写文档解析脚本 4.构建向量数据库 三、基于DS,使用本地知识库检索 本地部署DS,其实非常简单,我写了一篇操作记录,我终于本地部署了DeepSeek-R1(图文全过程)-CSDN博客 安装…

监控视频联网平台在智慧水利中的应用

随着智慧城市建设的深入推进&#xff0c;智慧水利作为其中的重要组成部分&#xff0c;正逐步实现数字化、智能化和网络化转型。在这一过程中&#xff0c;监控视频联网平台凭借其高效的数据采集、传输与分析能力&#xff0c;成为智慧水利建设的关键技术支撑。以下是监控视频联网…

深入解析素数筛法:从埃氏筛到欧拉筛的算法思想与实现

素数筛法是一种用于高效生成素数的算法。常见的素数筛法包括埃拉托斯特尼筛法&#xff08;埃氏筛&#xff09;和欧拉筛&#xff08;线性筛&#xff09;。下面我们将详细讲解这两种筛法的思想&#xff1a; 一、 埃拉托斯特尼筛法&#xff08;埃氏筛&#xff09; 思想&#xff1…

ubuntu20.04系统没有WiFi图标解决方案_安装Intel网卡驱动

文章目录 1. wifi网卡配置1.1 安装intel官方网卡驱动backport1.1.1 第四步可能会出现问题 1.2 ubuntu官方的驱动1.3 重启 1. wifi网卡配置 我的电脑是华硕天选4&#xff08;i7&#xff0c;4060&#xff09;&#xff0c;网卡型号intel ax201 ax211 ax210通用。 参考文章&#…

网络编程---多客户端服务器

写一个服务器和两个客户端 运行服务器和2个客户端&#xff0c;实现聊天功能 客户端1 和 客户端2 进行聊天 客户端1将聊天数据发送给服务器 服务器将聊天数据转发给客户端2 要求&#xff1a; 服务器使用 select 模型实现 客户端1使用 poll 模型实现 客户端2使用 多线程实现…

LeetCode 2614.对角线上的质数:遍历(质数判断)

【LetMeFly】2614.对角线上的质数&#xff1a;遍历(质数判断) 力扣题目链接&#xff1a;https://leetcode.cn/problems/prime-in-diagonal/ 给你一个下标从 0 开始的二维整数数组 nums 。 返回位于 nums 至少一条 对角线 上的最大 质数 。如果任一对角线上均不存在质数&…

红日靶场(二)——个人笔记

靶场搭建 新增VMnet2网卡 **web&#xff1a;**需要配置两张网卡&#xff0c;分别是外网出访NAT模式和内网域环境仅主机模式下的VMnet2网卡。 **PC&#xff1a;**跟web一样&#xff0c;也是需要配置两张网卡&#xff0c;分别是外网出访NAT模式和内网域环境仅主机模式下的VMn…

实时视频分析的破局之道:蓝耘 MaaS 如何与海螺 AI 视频实现高效协同

一、蓝耘 MaaS 平台&#xff1a;AI 模型全生命周期管理的智能引擎 蓝耘 MaaS&#xff08;Model-as-a-Service&#xff09;平台是由蓝耘科技推出的 AI 模型全生命周期管理平台&#xff0c;专注于为企业和开发者提供从模型训练、推理到部署的一站式解决方案。依托云原生架构、高…

走进Java:String字符串的基本使用

❀❀❀ 大佬求个关注吧~祝您开心每一天 ❀❀❀ 目录 一、什么是String 二、如何定义一个String 1. 用双引号定义 2. 通过构造函数定义 三、String中的一些常用方法 1 字符串比较 1.1 字符串使用 1.2 字符串使用equals() 1.3 使用 equalsIgnoreCase() 1.4 cpmpareTo…

python系列之元组(Tuple)

不为失败找理由&#xff0c;只为成功找方法。所有的不甘&#xff0c;因为还心存梦想&#xff0c;所以在你放弃之前&#xff0c;好好拼一把&#xff0c;只怕心老&#xff0c;不怕路长。 python系列之元组&#xff08;Turple&#xff09; 一、元组是什么&#xff1f;——给新手的…

破解验证码新利器:基于百度OCR与captcha-killer-modified插件的免费调用教程

破解验证码新利器&#xff1a;基于百度OCR与captcha-killer-modified插件的免费调用教程 引言 免责声明&#xff1a; 本文提供的信息仅供参考&#xff0c;不承担因操作产生的任何损失。读者需自行判断内容适用性&#xff0c;并遵守法律法规。作者不鼓励非法行为&#xff0c;保…

批量删除 PPT 中的所有图片、某张指定图片或者所有二维码图片

PPT 文档中的图片如何删除呢&#xff1f;相信很多小伙伴或碰到类似的需求。比如我们需要删除 PPT 文档中的某一张图片或者某张二维码图片&#xff0c;如果每一页都有这张图片&#xff0c;或者有很多 ppt 都有同一张要删除的图片&#xff0c;我们应该怎么快速的完成删除呢&#…

大模型开发(六):LoRA项目——新媒体评论智能分类与信息抽取系统

LoRA项目——新媒体评论智能分类与信息抽取系统 0 前言1 项目介绍1.1 项目功能1.2 技术原理1.3 软硬件环境1.4 项目结构 2 数据介绍与处理2.1 数据集介绍2.2 数据处理2.3 数据导入器 3 模型训练3.1 配置文件3.2 工具函数3.3 模型训练3.4 模型评估 4 模型推理 0 前言 微调里面&…