C++基础知识(八:STL标准库 deque )

deque在C++的STL(Standard Template Library)中是一个非常强大的容器,它的全称是“Double-Ended Queue”,即双端队列。deque结合了数组和链表的优点,提供了在两端进行高效插入和删除操作的能力,同时保持了随机访问的特性。

双端队列和普通队列的区别?

普通队列(queue)

  • 先进先出(FIFO)原则:普通队列遵循先进先出的原则,这意味着最先加入队列的元素将是最先被移除的。
  • 操作限制:在普通队列中,新的元素只能从队尾(rear)添加(enqueue),而元素的移除只能从队头(front)进行(dequeue)。

双端队列(deque)

  • 灵活的操作:双端队列允许在队列的两端进行插入和删除操作。这意呀着元素可以从队头(front)或队尾(rear)添加或移除。
  • 不限制操作端:双端队列没有固定的操作端限制,因此它不是严格意义上的FIFO数据结构,而是更加灵活。

总结区别

  1. 操作端

    • 普通队列只允许在一端插入(队尾)和另一端删除(队头)。
    • 双端队列允许在两端进行插入和删除。
  2. 数据访问

    • 普通队列中,数据访问遵循先进先出原则。
    • 双端队列中,数据访问更灵活,可以在两端进行访问,不严格遵循先进先出原则。
  3. 使用场景

    • 普通队列常用于需要按顺序处理任务的情况,如打印机任务队列、事件处理队列等。
    • 双端队列适用于需要灵活操作数据的情况,如滑动窗口算法、最近最少使用(LRU)缓存算法等。

deque的特点:

  1. 动态大小deque可以动态地增加或减少元素数量。
  2. 随机访问deque支持通过下标直接访问元素,时间复杂度为O(1)。
  3. 两端操作deque可以在头部和尾部进行快速的插入和删除操作,时间复杂度通常为O(1)。
  4. 内部实现deque使用一种复杂的内部结构来实现其特性,它将数据分割成多个连续的块,每个块的大小通常是固定的,这样既保证了随机访问的效率,又允许在两端进行高效的插入和删除。

deque的基本操作:

  • 构造与初始化

    • std::deque<int> d; // 创建一个空的deque
    • std::deque<int> d(10, 5); // 创建一个含有10个元素,每个元素值为5的deque
  • 插入与删除

    • d.push_front(1); // 在deque前端插入元素
    • d.push_back(2); // 在deque后端插入元素
    • d.pop_front(); // 删除deque前端的元素
    • d.pop_back(); // 删除deque后端的元素
    • d.insert(d.begin(), 0); // 在指定位置插入元素
    • d.erase(d.begin()); // 删除指定位置的元素
  • 访问元素

    • d.front(); // 访问deque的第一个元素
    • d.back(); // 访问deque的最后一个元素
    • d.at(index); // 访问指定索引的元素,如果索引越界会抛出异常
    • d[index]; // 直接通过下标访问元素
  • 其他操作

    • d.size(); // 获取deque中的元素数量
    • d.empty(); // 检查deque是否为空
    • d.clear(); // 清空deque中的所有元素

示例代码:

Cpp

#include <iostream>
#include <deque>int main()
{std::deque<int> d;// 插入元素d.push_back(1);d.push_front(2);d.push_back(3);// 访问元素std::cout << "Front: " << d.front() << ", Back: " << d.back() << std::endl;// 删除元素d.pop_front();d.pop_back();for (std::size_t i = 0; i < d.size(); ++i){std::cout << "d-value: " << d[i] << std::endl;}return 0;
}

什么时候用deque,什么时候用vector,什么时候用list?

std::vector

  • 使用场景

    • 当你需要频繁的随机访问元素时。
    • 当插入和删除操作主要发生在容器的末端时。
    • 当容器的大小在初始化后变化不大,或者可以预先分配足够空间时。
  • 优点

    • 提供随机访问,访问时间复杂度为O(1)。
    • 插入和删除元素在末尾时效率高,时间复杂度为O(1)。
    • 内存使用紧凑,元素在一块连续的内存区域中。
  • 缺点

    • 在中间或开头插入或删除元素时效率低,时间复杂度为O(n)。

std::deque

  • 使用场景

    • 当你需要在容器的头部和尾部频繁地插入和删除元素时。
    • 当你希望保持随机访问能力时。
  • 优点

    • 支持在头部和尾部的高效插入和删除,时间复杂度通常为O(1)。
    • 提供随机访问,时间复杂度为O(1)。
  • 缺点

    • 在中间位置插入或删除元素效率不如std::list
    • 内存使用比std::vector分散,因为元素分布在多个块中。

std::list

  • 使用场景

    • 当你需要在容器的任意位置频繁插入和删除元素时。
    • 当随机访问不是主要操作时。
  • 优点

    • 在列表的任意位置插入和删除元素都非常高效,时间复杂度为O(1)。
    • 不需要连续的内存空间,因此在内存分配方面更灵活。
  • 缺点

    • 不支持随机访问,访问时间复杂度为O(n)。
    • 遍历整个列表时可能比std::vectorstd::deque慢。

总结

  • 如果需要大量随机访问且插入删除操作集中在末尾,使用std::vector
  • 如果需要在两端高效插入删除且随机访问,使用std::deque
  • 如果需要在任意位置频繁插入删除且不关心随机访问,使用std::list

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/26587.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

#慧眼识模每日PK[话题]##用五种语言说爸爸我爱你[话题]#

#慧眼识模每日PK #用五种语言说爸爸我爱你 你觉得哪个模型回答得更好&#xff1f;欢迎留言 A.蓝 B.紫 更多问题&#xff0c;扫码体验吧&#xff5e; by 国家&#xff08;杭州&#xff09;新型交换中心

养猫发现猫毛过敏?宠物空气净化器真的能拯救猫毛过敏吗?

广东省 猫咪是许多人梦寐以求的伴侣&#xff0c;但对于轻度猫毛过敏和鼻炎患者来说&#xff0c;养猫似乎是个遥不可及的梦想。我常在社交媒体上羡慕地观看朋友们的吸猫日常&#xff0c;却因过敏无法亲自养猫。这种遗憾驱使我寻找解决方案&#xff0c;从研究低过敏猫种到尝试空气…

2024/06/13--代码随想录算法3/17|01背包问题 二维、01背包问题 一维、416. 分割等和子集

01背包问题 二维 卡码网链接 动态规划5步曲 确定dp数组&#xff08;dp table&#xff09;以及下标的含义&#xff1a;dp[i][j] &#xff1a;从下标为[0,i-1]个物品中任取&#xff0c;放进容量为j的背包&#xff0c;价值总和最大为多少。确定递推公式&#xff0c; 有两个方向可…

算法专题总结链接地址

刷力扣的时候会遇到一些总结类型的题解&#xff0c;在此记录&#xff0c;方便自己以后找 前缀和 前缀和https://leetcode.cn/problems/unique-substrings-in-wraparound-string/solutions/432752/xi-fa-dai-ni-xue-suan-fa-yi-ci-gao-ding-qian-zhui-/ 单调栈 单调栈https:…

Javaweb04-Servlet技术2(HttpServletResponse, HttpServletRequest)

Servlet技术基础 HttpServletResponse对象 HttpServletResponce对象是继承ServletResponse接口&#xff0c;专门用于封装Http请求 HttpServletResponce有关响应行的方法 方法说明功能描述void setStatus(int stauts)用于设置HTTP响应消息的状态码&#xff0c;并生成响应状态…

第17章通信系统架构设计理论与实践

常见的5种常用的网络架构和构建网络的相关技术&#xff0c;以及网络构建的分析和设计方法。 17.1通信系统概述 通信技术和网络技术的发展&#xff0c;通信网络发生很大变化&#xff0c;入网的形式变化&#xff0c;传输的速率的提高、接入网络的方式多样化、网络结构的更为复杂…

~$开头的临时文件是什么?可以删除吗?

&#xff08;2023.12.4&#xff09; 在进行Word文档编辑的时候&#xff0c;都会产生一个以~$开头的临时文件&#xff0c;它会自动备份文档编辑内容&#xff0c;若是正常关闭程序&#xff0c;这个文档就会自动消失&#xff1b;而在非正常情况下关闭word文档&#xff0c;如断电&…

考研计组chap2数据的表示和运算(补充)

一、进位计数制 1.r进制 第i位表示r进制的权为i 2.进制转换 &#xff08;1&#xff09;r->10 对应位置数*权值 &#xff08;2&#xff09;2 -> 16 or 8 每三位2进制数可表示1位16进制 每四位2进制数可表示1位16进制 so 分开之后转为16进制即可 eg&#xff1a;11…

JDK8新特性【接口新特征、lambda语法、Supplier、Consumer、Function、Predicate】

目录 一、关于接口的新特性1.1 jdk1.8之前的接口重要特性1.2 JDK8以后代码演示 1.3 总结通过代码演示发现作用 二、Lambda表达式[重点]2.1 将匿名内部类写法改写为lambda写法2.2 语法特点能够写成lambda形式的的前提语法特征代码演示深入理解lambda 2.3 总结 三、函数式接口3.1…

ISO17025认证是什么?怎么做?

ISO17025认证是一种国际通用的实验室质量管理体系认证&#xff0c;其目标是确保实验室的技术能力、管理水平以及测试结果的可靠性和准确性达到国际认可的标准。该认证由国际标准化组织&#xff08;ISO&#xff09;和国际电工委员会&#xff08;IEC&#xff09;联合发布&#xf…

pytorch神经网络训练(AlexNet)

导包 import osimport torchimport torch.nn as nnimport torch.optim as optimfrom torch.utils.data import Dataset, DataLoaderfrom PIL import Imagefrom torchvision import models, transforms 定义自定义图像数据集 class CustomImageDataset(Dataset): 定义一个自…

美丽的拉萨,神奇的布达拉宫

原文链接&#xff1a;美丽的拉萨&#xff0c;神奇的布达拉宫 2022年11月30日&#xff0c;可能将成为一个改变人类历史的日子——美国人工智能开发机构OpenAI推出了聊天机器人ChatGPT-3.5&#xff0c;将人工智能的发展推向了一个新的高度。2023年11月7日&#xff0c;OpenAI首届…

TcpClient 服务器、客户端连接

TcpClient 服务器 TcpListener 搭建tcp服务器的类&#xff0c;基于socket套接字通信的 1 创建服务器对象 TcpListener server new TcpListener(IPAddress.Parse("127.0.0.1"), 3000); 2 开启服务器 设置最大连接数 server.Start(1000); 3 接收客户端的链接,只能…

Android帧绘制流程深度解析 (二)

书接上回&#xff1a;Android帧绘制流程深度解析 &#xff08;一&#xff09; 5、 dispatchVsync&#xff1a; 在请求Vsync以后&#xff0c;choreographer会等待Vsync的到来&#xff0c;在Vsync信号到来后&#xff0c;会触发dispatchVsync函数&#xff0c;从而调用onVsync方法…

手机和模拟器的 Frida 环境配置

目录 一、配置 JDK 和 android 环境 二、连接设备和查看权限 1、连接设备 2、查看手机权限 三、手机配置 Frida 1、frida-server下载 2、验证 四、模拟器配置 Frida 1、下载模拟器并调节成手机版&#xff1a; 2、连接并查看架构 3、配置并开启 x86 的 frida-serve…

Phybers:脑纤维束分析软件包

摘要 本研究提供了一个用于分析脑纤维束数据的Python库(Phybers)。纤维束数据集包含由表示主要白质通路的3D点组成的流线(也称为纤维束)。目前已经提出了一些算法来分析这些数据&#xff0c;包括聚类、分割和可视化方法。由于流线的几何复杂性、文件格式和数据集的大小(可能包…

HTML静态网页成品作业(HTML+CSS)—— 环保主题介绍网页(5个页面)

&#x1f389;不定期分享源码&#xff0c;关注不丢失哦 文章目录 一、作品介绍二、作品演示三、代码目录四、网站代码HTML部分代码 五、源码获取 一、作品介绍 &#x1f3f7;️本套采用HTMLCSS&#xff0c;未使用Javacsript代码&#xff0c;共有5个页面。 二、作品演示 三、代…

多层tablayout+ViewPager,NestedScrollView+ViewPager+RecyclerView,嵌套吸顶滑动冲突

先看实现的UI效果 其实就是仿BOSS的页面效果&#xff0c;第二层tab下的viewpager滑到最右边再右滑&#xff0c;就操作第一层viewpager滑动。页面上滑时把第一层tab和vp里的banner都推出界面&#xff0c;让第二层tab吸顶。 滑上去第二个tab块卡在顶部&#xff0c;如图 我混乱…

React 渲染函数render、初始化函数、更新函数运行了两次,原因为何,如何解决? React.StrictMode

文章目录 Intro官网解释解决另一篇官网文章——初始化函数或更新函数运行了两次 Intro 我在用 react 写一个 demo &#xff0c;当我在某个自定义组件的 return 语句之前加上一句log之后&#xff0c;发现&#xff1a;每次页面重新渲染&#xff0c;该行日志都打印了两次&#xf…

vue-loader

Vue Loader 是一个 webpack 的 loader&#xff0c;它允许你以一种名为单文件组件 (SFCs)的格式撰写 Vue 组件 起步 安装 npm install vue --save npm install webpack webpack-cli style-loader css-loader html-webpack-plugin vue-loader vue-template-compiler webpack…