题外: 'A' +1='B'

1、deque被称为双端队列,它也是一种顺序容器。可通过迭代器存取元素 ,也可以通过下标顺序 存取元素

for(i=0;i<d1.size();i++)

{

cout<<d1[i];

d1[i] = 0;
}

2、deque具有的性质

<1> 利用位置索引可以存取容器中的元素

<2> 可以通过任何顺序迭代容器中的元素

<3> 可以在容器的开始和末尾追加/删除元素

3、需要的命令

#include<deque>

using namespace std;

构造类函数

1、创建deque容器并初始化容器中的元素

<1>deque<int> d1;---------------------------------作用是构造一个空洞deque容器,该容器内容为空

<2>deque<int> d2(5,10);--------------------------作用是将10的值 重复5次 存放到容器中

<3>deque<int> d3(d2.begin(),d2.end());--------作用是将输入对象中迭代器first和last之间的元素存放到容器中

<4>deque<int> d4(d3);----------------------------作用是用另一个双端队列 初始化deque容器

2、析构函数 ~deque()  在程序结束时由系统自动调用

3、operator(运算符)= 函数 -----------赋值deque中的内容

例:d2 = d1; -------------------用d1中的元素替换掉 d2中的 元素

迭代器函数

1、deque容器 包含四个迭代器 begin end rbegin rend

2、注意:begin函数返回第一个元素的位置;end函数返回最后一个元素的后一个位置; rbegin函数返回第一个元素之前的位置;rend函数返回最后一个元素的位置

front函数 返回第一个元素  ;back函数返回最后一个元素

3、声明迭代器--------deque<数据类型>::iterator it;

用例:deque<char>::iterator it;

迭代器与迭代器函数配合使用-------用例:it=d1.begin()

容量类函数

1、size函数返回deque容器实际元素个数,max_size函数返回deque容器所能容纳的最大元素个数

2、empty函数的作用是判断deque容器是否为空,为空返回true,不为空返回false

3、resize函数的作用是重新调整deque容器的大小(改变deque容器的实际元素个数,而不是容器的存储空间大小),使其包含sz个元素

如果sz小于原来deque容器的大小,则第sz之后的元素被抛弃 --------------------d.resize(3)

如果sz大于原来deque容器的大小,这容器的大小扩展为sz个元素并在末尾追加元素c。如果省略了参数c,则插入的元素值为0--------------d.resize(8,50)---50是c

存取类函数-----operator[]函数、at函数和、front函数、back函数

1、operator[]函数----------------类似于数组下标的东西,但是不会进行越界检查(deque 第一个元素 的下标由0开始)

2、at函数------作用于operator[]函数类似 但是会自动越界检查 如果越界则抛出一个异常

用例:cout<<d.at(0);

3、 front 与 back 函数

操作类函数

1、assin函数---------作用是将元素赋值给当前的deque容器,覆盖之前存在的全部内容

<1> 利用迭代器 将[first,last)之前的元素赋值给当前的deque容器---------d2.assign(d1.begin()+2,d1.end()-1)

<2>将重复的n个元素值u赋值给当前的deque容器-------------------d2.assign(6,10)------6个10

2、push_back函数的作用是在deque容器的最后一个元素之后添加元素x,容器个数加一-----------------d.push_back(x);

3、push_front函数的作用是在deque容器的第一个元素之前添加元素x,容器个数加一-----------------d.push_front(x);、

4、pop_back函数的作用是移除deque容器中的最后一个元素,容器个数减一--------------------------d.pop_back(x);

5、pop_front函数的作用是移除deque容器中的第一个元素,容器个数减一--------------------------d.pop_front(x);

6、insert函数的作用是在deque 的指定位置插入元素x------------------------------双端队列的insert可以在任意位置插入元素,最前面最后面都行(push)

指定位置(即position的位置)  通常是通过迭代器来实现的

<1>第一个函数的作用是将x插入到deque容器中第position个元素之前-----------------返回新插入元素的迭代器-----it= d.insert(it,10)

<2>第二个函数的作用是将n个x插入到deque容器中第position个元素之前------------------------无返回值---------- d.insert(it,2,20)----2个20

<3>第三个函数的作用是将输入对象中的[first,last)之间的元素插入到第position个元素之前------------无返回值-----d.insert(it,d1.begin(),d1.end()-1);

7、erase函数-----------删除deque中的指定的元素-----------容器自动往前移动

指定位置(即position的位置)  通常是通过迭代器来实现的

<1>第一个函数的作用是删除deque容器中的第position个元素

<2>第二个函数的作用是撒谎拿出deque容器中的[first,last)之间的元素

函数返回  deque容器中最后被删除元素的后一个位置

8、clear函数----------清除deque中的所有元素------调用后容器内元素个数为0

用法:  d.clear();

9、swap函数------------交换两个deque容器中的内容

用例:d1.swap(d2);

deque 类的更多相关文章

  1. python中deque类详解

    最近在pythonTip做题的时候,遇到了deque类,以前对其不太了解,现在特此总结一下 deque类是python标准库collections模块中的一项,它提供了两端都可以操作的序列,这意味着, ...

  2. deque用法 和与vector的区别

    deque是双向开口的连续性存储空间.虽说是连续性存储空间,但这种连续性只是表面上的,实际上它的内存是动态分配的,它在堆上分配了一块一块的动态储存区,每一块动态存储去本身是连续的,deque自身的机制 ...

  3. STL中deque

    以下学习一下STL中另一种序列容器——deque. deque表示double-ended queue,即双向队列,deque是通过作为动态数组的方式实现的,这样可以在两端插入元素.因此,deque可 ...

  4. C++ 头文件系列(deque)

    简介 deque是double ended queue(即双端队列)的简称. 就像C++中的大部分容器的一样,deque具有以下属性: 顺序的(sequence) 动态增长的(dynamic grow ...

  5. STL:deque用法详解

    deque函数: deque容器为一个给定类型的元素进行线性处理,像向量一样,它能够快速地随机访问任一个元素,并且能够高效地插入和删除容器的尾部元素.但它又与vector不同,deque支持高效插入和 ...

  6. Deque(队列)

    目录 Deque 概述 特点 常用方法 双向队列操作 ArrayDeque Deque 概述 一个线性 collection,支持在两端插入和移除元素.名称 deque 是"double e ...

  7. STL之三:deque用法详解

    转载于:http://blog.csdn.net/longshengguoji/article/details/8519812 deque函数: deque容器为一个给定类型的元素进行线性处理,像向量 ...

  8. std::deque

    deque容器为一个给定类型的元素进行线性处理,像向量一样,它能够快速地随机访问任一个元素,并且能够高效地插入和删除容器的尾部元素.但它又与vector不同,deque支持高效插入和删除容器的头部元素 ...

  9. <软件架构与设计模式>侯捷老师关于Adapter类在STL中的深入解析和模式探讨

    题外话:侯捷老师难得一年就来上九堂课就要会宝岛,特此留念签名赠语及合照以自勉.  学海无涯,为勤是岸 <正文开始> 昨天晚上连上了3个小时的大课探究单单讲了Adapter一个类,幸运的是本 ...

随机推荐

  1. Windows环境中,通过Charles工具,抓取安卓手机、苹果手机中APP应用的http、https请求包信息

    Windows环境中,通过Charles工具,抓取安卓手机.苹果手机中APP应用的http.https请求包信息1.抓取安卓手机中APP应用的http请求包信息1)在电脑上操作,查看Windows机器 ...

  2. python 之网页解析器

    一.什么是网页解析器 1.网页解析器名词解释 首先让我们来了解下,什么是网页解析器,简单的说就是用来解析html网页的工具,准确的说:它是一个HTML网页信息提取工具,就是从html网页中解析提取出“ ...

  3. C、C++、C#中struct的简单比较

    比较这三者是因为C.C++.C#这三者存在着一定的血缘关系,而他们三者都有的struct却有很大的不同. 功能 C中的struct是最简单的.只能有成员变量而不能有成员函数. C++和C#中都支持,而 ...

  4. C# 生成条形码图片

    在网上看到一些人写关于条形码的代码都很长,有的甚至拿来卖,所以查了下资料,希望能对大家有帮助. 我的实现原理是: 其实Windows本身就有一个字体是用来显示条形码的. 只要将数字改为这种字体就变成了 ...

  5. 报bug

    在打印输出seg的gt数据的时候,出现了gt数据突然很大突然很小的情况,一般这种都是访问了其他内存

  6. Spring boot 集成Kafka

    搭建Kafka集群,参考: https://www.cnblogs.com/jonban/p/kafka.html 源码示例如下: 1.新建 Maven 项目 kafka 2.pom.xml < ...

  7. kubernetes-深入理解pod对象(七)

    Pod中如何管理多个容器 Pod中可以同时运行多个进程(作为容器运行)协同工作.同一个Pod中的容器会自动的分配到同一个 node 上.同一个Pod中的容器共享资源.网络环境和依赖,它们总是被同时调度 ...

  8. ajax的序列化表单提交

    通过传统的 form 表单提交的方式上传文件 ? 1 2 3 4 <form id="uploadForm" action="" method=" ...

  9. 01_12_Struts2_访问Web元素

    01_12_Struts2_访问Web元素 1. 配置struts.xml文件 <package name="login" namespace="/login&qu ...

  10. SDWebImage解析

    SDWebImage托管在github上.https://github.com/rs/SDWebImage 这个类库提供一个UIImageView类别以支持加载来自网络的远程图片.具有缓存管理.异步下 ...