当前位置: 首页 > news >正文

vector容器以及deque

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(); //删除容器第一个数据

相关文章:

  • 嵌入式c学习六
  • 硬件基础(5):(2)二极管分类
  • 如何编译鲁班猫(LubanCat 1N)固件
  • HTTP/HTTPS
  • 前端小食堂 | Day18 - 身份认证の八卦阵
  • LORA 中的 梯度外积是什么意思; 方差和协方差的实际含义:衡量变量的离散程度和变量间的线性相关性
  • 信息系统运行管理员教程4--信息系统软件运维
  • 【Linux———线程精讲】
  • electron js node vscode 调试electron
  • 实验4 Vue.js路由实验
  • Can通信流程
  • 【Linux网络-数据链路层】以太网(以太网帧格式|MAC地址+模拟一次性局域网通信+MTU)+ARP协议
  • 09 python函数(上)
  • UE学习记录part7
  • 免密登录远程服务器shell脚本
  • 【Linux】:守护进程化
  • 工具层handle_excel
  • Java-泛型总结
  • 蓝桥杯备考:奶牛晒衣服
  • Android NDK --- JNI从入门到基础的全面掌握 (上)
  • “85后”潘欢欢已任河南中豫融资担保有限公司总经理
  • 日月谭天丨赖清德强推“脱中入北”是把台湾带向死路
  • 李公明|一周画记:哈佛打响第一枪
  • 原创话剧风向标!这个展演上《大宅门》《白鹿原》先后上演
  • 中日友好医院通报“医师肖某被举报”:基本属实,开除党籍并解聘
  • 视频丨伊朗阿巴斯港一处油罐发生高强度爆炸:造成大面积破坏,伤亡不明