目录
一、deque容器基本概念
功能
- 双端数组,可以对头端进行插入删除操作
deque与vector区别
- vector对于头部的插入删除效率低,数据量越大,效率越低
- deque相对而言,对头部的插入删除速度会比vector快
- vector访问元素时的速度会比deque快,这和两者内部实现有关
- deque容器的迭代器也是支持随机访问的
二、deque容器构造函数
函数原型
- deque<T> deqT; //默认构造形式
- deque(beg,end); //构造函数将[beg, end]区间中的元素拷贝给本身
- deque(n , elem); //构造函数将n个elem拷贝给本身
- deque(const deque &deq); //拷贝构造函数
#include <iostream>
#include <deque>
using namespace std;
void printDeque(const deque<int> &d)
{
for (deque<int>::const_iterator it = d.begin(); it != d.end(); it++)
{
//*it =100; 容器中的数据不可以修改
cout << *it << " ";
}
cout << endl;
}
void test01()
{
deque<int> d1;
for (int i = 0; i < 10; i++)
{
d1.push_back(i);
}
printDeque(d1);
deque<int>d2(d1.begin(), d1.end());
printDeque(d2);
deque<int> d3(10, 88);
printDeque(d3);
deque<int>d4(d3);
printDeque(d4);
}
int main()
{
test01();
}
三、deque赋值操作
函数原型
- deque& operator=(const deque &deq); //重载等号操作符
- assign(beg, end); //将[begin ,end]区间中的数据拷贝赋值给本身
- assign(n, elem) ; //将n个elem拷贝赋值给本身
deque<int> d1;
for (int i = 0; i < 10; i++)
{
d1.push_back(i);
}
printDeque(d1);
deque<int>d2;
d2 = d1;
printDeque(d2);
deque<int>d3;
deque<int>::iterator it = d2.begin();
d3.assign(it + 2, d2.end());
printDeque(d3);
deque<int>d4;
d4.assign(10, 88);
printDeque(d4);
四、deque大小操作
函数原型 (跟vector类似,见3.2内容)
- deque.empty(); //判断容器是否为空
- deque.size(); //返回容器中元素个数
- deque.resize(num); //重新指定容器的长度为num,若容器变长,则以默认值填充新位置
- //如果容器变短,则末尾超出容器长度的元素被删除
- deque.resize(num,elem) ;//重新指定容器的长度为num,若容器变长,则以elem值填充新位置
-
//如果容器变短,则末尾超出容器长度的元素被删除
五、deque插入和删除
函数原型
- push_back(elem); //尾部插入元素elem
- push_front(elem); //在容器头部插入一个数据elem
- pop_back(); //删除最后一个元素
- pop_front(); //删除容器第一个元素
指定位置操作
- insert(const_iterator pos, ele); //迭代器指向位置pos插入元素ele
- insert(const_iterator pos, int count, ele); //迭代器指向位置pos插入count个元素ele
- insert(pos,beg, end); //在pos位置插入 【beg,end】区间的数据,无返回值
- clear(); //清空容器中所有数据
- erase(const_iterator beg,const_iterator end); //删除迭代器从beg到end之间的元素
- erase(pos); //删除pos位置的数据,返回下一个数据的位置
六、deque数据存取
函数原型
- at(int idx); //返回索引idx所指的数据
- operator[idx]; //返回索引idx所指的数据
- front() ; //返回容器中第一个数据元素
- back(); //返回容器中最后一个数据元素
七、deque排序
算法
- sort(iterator beg, iterator end); //对beg 和end区间内元素进行排序
deque<int> d1;
d1.push_back(10);
d1.push_back(20);
d1.push_back(50);
d1.push_back(8);
d1.push_back(500);
d1.push_back(300);
printDeque(d1);
//排序 从小到大
sort(d1.begin(), d1.end());
printDeque(d1);