deque容器

deque容器

功能:
双端数组,可以对头端进行插入删除操作
deque与vector区别:
vector对于头部的插入删除效率低,数据量越大,效率越低 deque相对而言,对头部的插入删除速度回比vector快 vector访问元素时的速度会比deque快,这和两者内部实现有关


deque内部工作原理: deque内部有个中控器,维护每段缓冲区中的内容,缓冲区中存放真实数据 中控器维护的是每个缓冲区的地址,使得使用deque时像一片连续的内存空间

注意:deque容器的迭代器也是支持随机访问的

deque构造函数

功能描述:
deque容器构造
函数原型:

deque<T> deqT;                   //默认构造形式 
deque(beg, end);                 //构造函数将[beg, end)区间中的元素拷贝给本身。 
deque(n, elem);                  //构造函数将n个elem拷贝给本身。 
deque(const deque &deq);  		 //拷贝构造函数

deque赋值操作

功能描述:
给deque容器进行赋值
函数原型:

deque& operator=(const deque &deq);         //重载等号操作符
assign(beg, end);                           //将[beg, end)区间中的数据拷贝赋值给本身。 
assign(n, elem);                            //将n个elem拷贝赋值给本身。

deque大小操作

功能描述:
对deque容器的大小进行操作
函数原型:

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

注意:deque没有容量的概念

deque 插入和删除

功能描述:
向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(); 				//清空容器的所有数据 
erase(beg,end);			//删除[beg,end)区间的数据,返回下一个数据的位置。 
erase(pos); 			//删除pos位置的数据,返回下一个数据的位置

注意:插入和删除提供的位置是迭代器

deque 数据存取

功能描述:
对deque 中的数据的存取操作
函数原型

at(int idx);     //返回索引idx所指的数据 
operator[];      //返回索引idx所指的数据 
front();         //返回容器中第一个数据元素 
back();          //返回容器中后一个数据元素

deque 排序

功能描述:
利用算法实现对deque容器进行排序
算法:

sort(iterator beg, iterator end)  //对beg和end区间内元素进行排序

注意:sort算法非常实用,使用时包含头文件 algorithm即可

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值