博客
关于我
C++中的queue(队列,容器适配器)和deque(双端队列,容器)的区别
阅读量:799 次
发布时间:2023-04-16

本文共 865 字,大约阅读时间需要 2 分钟。

queue操作:(容器适配器)

在C++中,queue(队列)是一个非常有用的容器适配器,主要用于实现先进先出的数据结构。以下是queue的基本操作:

queue q;    // 创建一个int型的空队列
q.empty(); // 判断队列是否为空,返回true表示为空
q.push(x); // 将变量x从队尾入队
q.pop(); // 弹出队列的前一个元素
q.front(); // 只返回队列的前一个元素
q.back(); // 只返回队列的最后一个元素
q.size(); // 返回队列中元素的总数

需要注意的是,queue的操作方式与stack有所不同。队列只支持从队尾(back)或前面(front)添加元素,而无法像栈那样只在一端添加或删除元素。

deque操作:(容器)

deque(双端队列)是一个支持在队列两端进行添加和删除操作的容器。与普通队列相比,deque的性能更优,因为它实现了优化的内存布局结构。以下是deque的主要操作:

deque q;    // 创建一个双端队列
q.empty(); // 判断双端队列是否为空,返回true表示为空
q.push_front(s); // 将s从队头入队
q.push_back(s); // 将s从队尾入队(与普通队列push操作方式一致)
q.front(); // 只返回队列的前一个元素
q.back(); // 只返回队列的最后一个元素
q.pop_front(); // 弹出队列的前一个元素
q.pop_back(); // 弹出队列的最后一个元素
q.clear(); // 清空整个双端队列

deque的优势在于其支持在两端同时进行push和pop操作,这对于需要从队列的两端同时读取或写入数据的场景尤为有用。例如,实时数据处理、多线程环境中的数据同步等都可以利用deque的高效操作特性。

转载地址:http://pkgfk.baihongyu.com/

你可能感兴趣的文章
MySQL 数据类型和属性
查看>>
mysql 敲错命令 想取消怎么办?
查看>>
Mysql 整形列的字节与存储范围
查看>>
mysql 断电数据损坏,无法启动
查看>>
MySQL 日期时间类型的选择
查看>>
Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
查看>>
MySQL 是如何加锁的?
查看>>
MySQL 是怎样运行的 - InnoDB数据页结构
查看>>
mysql 更新子表_mysql 在update中实现子查询的方式
查看>>
MySQL 有什么优点?
查看>>
mysql 权限整理记录
查看>>
mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
查看>>
MYSQL 查看最大连接数和修改最大连接数
查看>>
MySQL 查看有哪些表
查看>>
mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
查看>>
MySql 查询以逗号分隔的字符串的方法(正则)
查看>>
MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
查看>>
mysql 查询数据库所有表的字段信息
查看>>
【Java基础】什么是面向对象?
查看>>
mysql 查询,正数降序排序,负数升序排序
查看>>