STL(第四课):deque

STL deque是标准模板库(STL)中的一个容器,deque是"double-ended queue"的缩写,它是一种双端队列的数据结构,允许在两端进行插入和删除操作。

STL deque中的元素存储在连续的内存块中,一般由多个缓冲区组成,每个缓冲区的大小固定。当插入元素时,如果当前缓冲区已满,则新增一个缓冲区并将元素插入到新缓冲区的开头;当删除元素时,如果当前缓冲区只剩下一个元素,则删除该元素并释放该缓冲区。

STL deque支持随机访问和迭代器,可以在任意位置进行插入和删除操作,也可以通过迭代器遍历元素。

STL deque常用的成员函数:

  1. push_front(val):在deque头部插入一个val元素;
  2. push_back(val):在deque尾部插入一个val元素;
  3. pop_front():删除deque头部的元素;
  4. pop_back():删除deque尾部的元素;
  5. front():返回deque头部的元素;
  6. back():返回deque尾部的元素;
  7. size():返回deque中元素的个数;
  8. clear():清空deque中的所有元素;
  9. empty():判断deque是否为空;
  10. begin():返回迭代器,指向deque头部的元素;
  11. end():返回迭代器,指向deque尾部的下一个位置;
  12. rbegin():返回反向迭代器,指向deque尾部的元素;
  13. rend():返回反向迭代器,指向deque头部的前一个位置。

STL deque的时间复杂度如下:

  1. 在deque头部或尾部插入或删除元素的时间复杂度为O(1);
  2. 随机访问deque中的元素的时间复杂度为O(1);
  3. 在deque中任意位置插入或删除元素的时间复杂度为O(n),其中n为deque中元素的个数。
相关推荐
得闲喝茶几秒前
JavaScript在数据处理的应用
开发语言·前端·javascript·经验分享·笔记
嵌入式×边缘AI:打怪升级日志1 分钟前
转换模块(十二):实现 RGB 转 RGB + 项目整合与上机实验
开发语言·ios·swift
研究点啥好呢5 分钟前
凯捷 自动化测试(Java+Selenium)面试题精选:10道高频考题+答案解析
java·开发语言·python·selenium·测试工具·求职招聘
会周易的程序员7 分钟前
aiDgeScanner架构与实现
c++·ide·物联网·架构·node.js·aiot
王老师青少年编程9 分钟前
csp信奥赛C++高频考点专项训练之字符串 --【字符串排序】:生日
c++·字符串·csp·高频考点·信奥赛·生日·字符串排序
ghie90909 分钟前
基于遗传算法的配电网重构
开发语言·重构
SilentSamsara11 分钟前
生成器进阶:`yield from`、协程历史与双向通信
开发语言·python·青少年编程·pycharm
kyle~15 分钟前
ROS2---消息过滤
开发语言·c++·机器人·ros2
xieliyu.16 分钟前
Java手搓二叉树:基础遍历与核心操作全解析
java·开发语言·数据结构·学习
期待のcode24 分钟前
Redis数据类型
运维·数据结构·redis