1、概念
deque与vector区别:
- vector对于头部的插入删除效率低,数据量越大,效率越低
- deque相对而言,对头部的插入删除速度回比vector快
- vector访问元素时的速度会比deque快,这和两者内部实现有关
2、基本赋值
构造函数赋值
- deque deqT; //默认构造形式
- deque(beg, end); //构造函数将[beg, end)区间中的元素拷贝给本身。
- deque(n, elem); //构造函数将n个elem拷贝给本身。
- deque(const deque &deq); //拷贝构造函数
=号赋值和assign:
-
deque& operator=(const deque &deq); //重载等号操作符 -
assign(beg, end); //将[beg, end)区间中的数据拷贝赋值给本身。 -
assign(n, elem); //将n个elem拷贝赋值给本身。
3、大小操作
函数原型:
- deque.empty(); //判断容器是否为空
- deque.size(); //返回容器中元素的个数
- deque.resize(num); //重新指定容器的长度为num,若容器变长,则以默认值填充新位置。
//如果容器变短,则末尾超出容器长度的元素被删除。 - deque.resize(num, elem); //重新指定容器的长度为num,若容器变长,则以elem值填充新位置。
//如果容器变短,则末尾超出容器长度的元素被删除。
4、示例代码
#include<iostream>
#include<string>
#include<deque>
using namespace std;
void printDeque(const deque<int>& d)
{
for (deque<int>::const_iterator it = d.begin();it != d.end();it++)
{
cout << *it << " ";
}
cout << endl;
}
void test01()
{
deque<int> d;
for (int i = 0;i < 10;i++)
{
d.push_front(i);
}
d.pop_front();
d.pop_back();
deque<int> d1(d.begin(), d.end());
deque<int> d2(10,100);
deque<int> d3(d2);
printDeque(d3);
}
void test02()
{
deque<int> d;
for (int i = 0;i < 10;i++)
{
d.push_front(i);
}
deque<int> d1 = d;
deque<int> d2;
d2.assign(d.begin(), d.end());
deque<int> d3;
d3.assign(10, 20);
printDeque(d3);
}
void test03()
{
deque<int> d;
for (int i = 0;i < 10;i++)
{
d.push_front(i);
}
if (d.empty())
{
cout << "数组为空" << endl;
}
else
{
cout << "数组不为空" << endl;
}
cout << "数组的大小:" << d.size() << endl;
d.resize(15,100);
d.resize(2);
printDeque(d);
}
int main()
{
test03();
return 0;
}
注意:deque没有容量的概念,是可以无限插入的
|