STL学习系列三:Deque容器

1.Deque简介

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

2.deque对象的默认构造

deque采用模板类实现,deque对象的默认构造形式:deque<T> deq;

deque <int> deqInt;            //一个存放int的deque容器。

deque <float> deq Float;     //一个存放float的deque容器。

3.deque对象的带参数构造

  • deque(beg,end);    //构造函数将[beg, end)区间中的元素拷贝给本身。注意该区间是左闭右开的区间。
  • deque(n,elem);   //构造函数将n个elem拷贝给本身。
  • deque(const deque  &deq);  //拷贝构造函数。
#include<iostream>
using namespace std;
#include <deque>
void objPlay3()
{
    deque<int> deqIntA;
    deqIntA.push_back(1);
    deqIntA.push_back(3);
    deqIntA.push_back(5);
    deqIntA.push_back(7);
    deqIntA.push_back(9);

    deque<int> deqIntB(deqIntA.begin(), deqIntA.end());      //1 3 5 7 9
    deque<int> deqIntC(5, 8);                               //8 8 8 8 8
    deque<int> deqIntD(deqIntA);                           //1 3 5 7 9
}
int main()
{
    objPlay3();
    return 0;
}

4.deque的赋值

  • deque.assign(beg,end);    //将[beg, end)区间中的数据拷贝赋值给本身。注意该区间是左闭右开的区间。
  • deque.assign(n,elem);  //将n个elem拷贝赋值给本身。
  • deque& operator=(const deque &deq);    //重载等号操作符
  • deque.swap(deq);  // 将vec与本身的元素互换
void objPlay4()
{
    deque<int> deqIntA, deqIntB, deqIntC, deqIntD;
    deqIntA.push_back(1);
    deqIntA.push_back(3);
    deqIntA.push_back(5);
    deqIntA.push_back(7);
    deqIntA.push_back(9);

    deqIntB.assign(deqIntA.begin(), deqIntA.end());   // 1 3 5 7 9
    deqIntC.assign(5, 8);                            //8 8 8 8 8
    deqIntD = deqIntA;                              //1 3 5 7 9
    deqIntC.swap(deqIntD);                         //C 和 D互换
}

5.deque的大小

  • deque.size();                     //返回容器中元素的个数。
  • deque.empty();                 //判断容器是否为空。
  • deque.resize(num);           //重新指定容器的长度为num,若容器变长,则以默认值填充新位置。如果容器变短,则末尾超出容器长度的元素被删除。
  • deque.resize(num, elem);  //重新指定容器的长度为num,若容器变长,则以elem值填充新位置。如果容器变短,则末尾超出容器长度的元素被删除。

void objPlay5()
{
  deque<int> deqIntA;
  deqIntA.push_back(1);
  deqIntA.push_back(3);
  deqIntA.push_back(5);

  int iSize = deqIntA.size(); //3

  if (!deqIntA.empty())
  {
    deqIntA.resize(5); //1 3 5 0 0
    deqIntA.resize(7, 1); //1 3 5 0 0 1 1
    deqIntA.resize(2); //1 3
  }

}

6.deque末尾的添加移除操作

  • deque.push_back(elem);   //在容器尾部添加一个数据
  • deque.push_front(elem);  //在容器头部插入一个数据
  • deque.pop_back();                  //删除容器最后一个数据
  • deque.pop_front();             //删除容器第一个数据

7.deque的数据存取

  • deque.at(idx);  //返回索引idx所指的数据,如果idx越界,抛出out_of_range。
  • deque[idx];  //返回索引idx所指的数据,如果idx越界,不抛出异常,直接出错。
  • deque.front();   //返回第一个数据。
  • deque.back();  //返回最后一个数据

8.deque的插入

  • deque.insert(pos,elem);   //在pos位置插入一个elem元素的拷贝,返回新数据的位置。
  • deque.insert(pos,n,elem);   //在pos位置插入n个elem数据,无返回值。
  • deque.insert(pos,beg,end);   //在pos位置插入[beg,end)区间的数据,无返回值。

9.deque的删除

  • deque.clear();    //移除容器的所有数据
  • deque.erase(beg,end);  //删除[beg,end)区间的数据,返回下一个数据的位置。
  • deque.erase(pos);    //删除pos位置的数据,返回下一个数据的位置。
时间: 2024-07-30 20:30:04

STL学习系列三:Deque容器的相关文章

标准模板库(STL)学习探究之vector容器

标准模板库(STL)学习探究之vector容器  C++ Vectors vector是C++标准模板库中的部分内容,它是一个多功能的,能够操作多种数据结构和算法的模板类和函数库.vector之所以被认为是一个容器,是因为它能够像容器一样存放各种类型的对象,简单地说,vector是一个能够存放任意类型的动态数组,能够增加和压缩数据.为了可以使用vector,必须在你的头文件中包含下面的代码:#include <vector>构造函数. Vectors 包含着一系列连续存储的元素,其行为和数组类

STL学习系列五:Queue容器

Queue简介 queue是队列容器,是一种“先进先出”的容器. queue是简单地装饰deque容器而成为另外的一种容器. #include <queue> 1.queue对象的默认构造 queue采用模板类实现,queue对象的默认构造形式:queue<T> queT; 如: queue<int> queInt; //一个存放int的queue容器. queue<float> queFloat; //一个存放float的queue容器. ... //尖括

STL学习系列四:Stack容器

Stack简介 stack是堆栈容器,是一种“先进后出”的容器. stack是简单地装饰deque容器而成为另外的一种容器. #include <stack> 1.stack对象的默认构造 stack采用模板类实现, stack对象的默认构造形式: stack <T> stkT; stack <int> stkInt;            //一个存放int的stack容器. stack <float> stkFloat;     //一个存放float的

Identity Server4学习系列三

1.简介 在Identity Server4学习系列一和Identity Server4学习系列二之令牌(Token)的概念的基础上,了解了Identity Server4的由来,以及令牌的相关知识,本文开始实战,实现Identity Server4基本的功能. 2.前提 本文基于.Net Core2.1和Indetity Server4 2.3.0,令牌处理包采用IdentityServer4.AccessTokenValidation 2.7.0 3.实战一Identity Server4服

C++——STL之vector, list, deque容器对比与常用函数

STL 三种顺序容器的特性对比: vector 可变数组,内存空间是连续的,容量不会进行缩减.支持高效随机存取,即支持[]和at()操作.尾部插入删除效率高,其他位置插删效率较低: list 双向链表,内存空间可不连续,不支持随机存取.插入和删除的效率很高: deque  双端队列,内存空间是多个连续的内存块,在一个映射结构中保存对这些块以及顺序的跟踪,可利用的内存更大,且内存大小是可以自动缩减的.支持随机存取,但是随机存取性能没有vector 好.首尾插入效率高,其他位置插删效率低: 使用注意

STL 笔记(三) 容器适配器 stack、queue、priority_queue

栈 stack 栈 stack 是一种先进后出的(First In Last Out, FILO)的数据结构.在 STL中,stack 底层容器默认使用的是deque, 也可以自己指定用 vector 或 list 容器,然后将其接口适配为栈的接口.部分源代码: // stack source code (部分) template <class _Tp, class _Sequence __STL_DEPENDENT_DEFAULT_TMPL(deque<_Tp>) > class

C# Redis学习系列三:Redis配置主从

Redis配置主从 主IP :端口      192.168.0.103 6666 从IP:端口       192.168.0.108 3333 配置从库 (1)安装服务: redis-server --service-install --service-name redisService6666 --port 6666 (2)启动进程: redis-server --service-start --service-name redisService6666 (3)连接redis:redis-

STL学习系列七:优先级队列priority_queue容器

1.简介 最大值优先级队列.最小值优先级队列 优先级队列适配器 STL priority_queue 用来开发一些特殊的应用,请对stl的类库,多做扩展性学习 如果我们给每个元素都分配一个数字来标记其优先级,不妨设较小的数字具有较高的优先级,这样我们就可以在一个集合中访问优先级最高的元素并对其进行查找和删除操作了.这样,我们就引入了优先级队列 这种数据结构. 优先级队列(priority queue) 是0个或多个元素的集合,每个元素都有一个优先权,对优先级队列执行的操作有(1)查找(2)插入一

STL学习系列六:List容器

List简介 list是一个双向链表容器,可高效地进行插入删除元素. list不可以随机存取元素,所以不支持at.(pos)函数与[]操作符.it++(ok), it+5(err) #include <list> 1.list对象的默认构造 list采用采用模板类实现,对象的默认构造形式:list<T> lstT;  如: list<int> lstInt;            //定义一个存放int的list容器. list<float> lstFloa