<a name="rubam"></a>
deque容器基本概念
Double ended queue
的简称<br />双端数据,可以对头端进行插入删除操作
- deque容器的迭代器也是支持随机访问的
deque与vector区别:
- vector对于头部的插入删除效率低,数据量越大,效率越低
- deque相对而言,对头部的插入删除速度比vector快
- vector访问元素时的速度会比deque快,这和两者内部实现有关
<br />deque内部工作原理:
- deque内部有一个中控器,维护每段缓冲区的内容,缓冲区中存放真实数据
- 中控器维护的是每个缓冲区的地址,使得使用deque时像一片连续的内存空间
<a name="Oh0ch"></a>
deque构造函数
-
deque<T>deqT;
//默认构造 -
deque(beg, end);
//构造函数将[beg,end)区间内的元素拷贝给自身 -
deque(n, ele);
//构造函数将n个ele拷贝给自身 -
deque(const deque& deq);
//拷贝构造函数
如果要限制一个容器为只读状态,那么他的迭代器也要发生改变
<a name="jvGG7"></a>
deque赋值操作
重载=运算符:
-
deque& operator=(const deque& deq);
assign方式赋值:
-
.assign(beg, end);
//将[beg,end)区间内的数据拷贝赋值给自身 -
.assign(n, elem);
//将n个elem拷贝赋值给自身
deque复制操作与vector相同,需要熟练掌握
<a name="YuWyl"></a>
deque大小操作
-
.empty();
//判断容器是否为空 -
.size();
//返回容器中元素的个数 -
.resize(int num);
//重新指定容器的长度为num,若容器变长,则以默认值0填充新位置;如果容器变短,则末尾超出容器长度的元素被删除 -
.resize(int num, elem);
//重新指定容器的长度为num,若容器变长,则以elem值填充新位置;如果容器变短,则末尾超出容器长度的元素被删除
注意与vector的区别:
- 没有
.capacity()
“容量”,因为内部结构没有容量限制,可以无限扩展
总结:
- deque没有容器的概念
- 判断是否为空:
.empty()
- 返回元素个数:
.size()
- 重新制定个数:
.resize()
<a name="bbF44"></a>
deque插入和删除
两端插入操作:
-
.push_back(elem);
//尾插 -
.push_front(elem);
//头插 -
.pop_back();
//尾删 -
.pop_front();
//头删
指定位置操作:
-
.insert(pos, elem);
//在pos位置插入elem元素的拷贝,返回新数据的位置 -
.insert(pos, n, elem);
//在pos位置插入n个elem元素数据,无返回值 -
.insert(pos, beg, end);
//在pos位置插入[beg,end)区间的数据,无返回值 -
.clear();
//清空容器内所有数据 -
.eraser(beg,end);
//删除[beg,end)区间的数据,返回下一个数据的位置 -
.erase(pos);
//删除pos位置的数据,返回下一个数据的位置
注意:
- 插入和删除提供的位置是迭代器
<a name="vJdWW"></a>
deque数据存取
-
.at(int idx);
//返回索引idx
所指的数据 -
operator[];
//返回索引idx
所指的数据 -
.front();
//返回容器中第一个元素的数据 -
.back();
//返回容器中最后一个元素的数据
<a name="rgsia"></a>
deque排序操作
sort(iterator beg, iterator end);
//对beg和end区间内的元素进行排序
- 默认的排序规则是升序:从小到大,
- 对于支持随机访问的迭代器的容器,都可以利用sort算法直接对其排序
- voctor容器也可以使用sort排序
sort算法非常实用,使用时包含头文件algorithm
即可