【C++练级之路】【Lv.9】【STL】stack类和queue类的模拟实现



快乐的流畅:个人主页


个人专栏:《C语言》《数据结构世界》《进击的C++》

远方有一堆篝火,在为久候之人燃烧!

文章目录

  • 一、容器适配器
  • 二、stack
    • 2.1 push
    • 2.2 pop
    • 2.3 top
    • 2.4 size
    • 2.5 empty
  • 三、queue
    • 3.1 push
    • 3.2 pop
    • 3.3 front
    • 3.4 back
    • 3.5 size
    • 3.6 empty
  • 四、deque
    • 4.1 deque的介绍
    • 4.2 deque的底层结构
    • 4.3 deque的优势与缺陷
    • 4.4 为什么选择deque作为stack和queue的底层默认容器
  • 总结

一、容器适配器

STL并没有将stack和queue划分为容器,而是将其称为容器适配器,原因是stack和queue只是对其他容器的接口进行了封装。

这也让stack和queue模拟实现起来异常简单,所以两个合在一起讲解介绍。

二、stack

细节:

  1. stack具有LIFO(后进先出)性质
  2. 默认容器使用vector,使用尾插尾删效率高(STL库中使用deque)
template<class T, class Container = vector<T>>
class stack
{
public:
private:Container _con;
};

2.1 push

压栈

void push(const T& x)
{_con.push_back(x);
}

2.2 pop

出栈

void pop()
{_con.pop_back();
}

2.3 top

获取栈顶元素

const T& top() const
{return _con.back();
}

2.4 size

获取栈的有效元素个数

size_t size() const
{return _con.size();
}

2.5 empty

判断栈是否为空

bool empty() const
{return _con.empty();
}

三、queue

细节:

  1. queue具有FIFO(先进先出)性质
  2. 默认容器使用list,使用尾插头删效率高(STL库中使用deque)
template<class T, class Container = list<T>>
class queue
{
public:
private:Container _con;
};

3.1 push

入队

void push(const T& x)
{_con.push_back(x);
}

3.2 pop

出队

void pop()
{_con.pop_front();
}

3.3 front

获取队头元素

const T& front() const
{return _con.front();
}

3.4 back

获取队尾元素

const T& back() const
{return _con.back();
}

3.5 size

获取队列的有效元素个数

size_t size() const
{return _con.size();
}

3.6 empty

判断队列是否为空

bool empty() const
{return _con.empty();
}

四、deque

4.1 deque的介绍

deque(双端队列):是一种双开口的"连续"空间的数据结构,双开口的含义是:可以在头尾两端进行插入和删除操作,且时间复杂度为O(1),与vector比较,头插效率高,不需要搬移元素;与list比较,空间利用率比较高。

4.2 deque的底层结构

其实,deque并不是一整块连续空间,而是一段一段连续的小空间结合在一起。deque有一个中控数组,存放一段段小空间的指针,类似动态开辟的二维数组。

一开始在中间开辟空间,随后根据需求向两边进行扩容。

所以,针对分段连续的空间结构,为了支持随机访问,设计出了比较复杂的迭代器。

这样的空间结构,也导致遍历的效率变得十分低下,因为deque的迭代器需要频繁判断是否抵达分段空间的边界

4.3 deque的优势与缺陷

优势:

  • 支持随机访问
  • 头尾的插入删除,时间复杂度为O(1)

缺陷:

  • 中间插入删除比较麻烦
  • 不适合遍历

总体来说,deque结合了vector和list的优势,却又没有vector和list的性能那么极致,在大部分场景下都不太常用,所以这里只是简单介绍,并不模拟实现底层结构。

4.4 为什么选择deque作为stack和queue的底层默认容器

原因有两点:

  1. stack和queue不需要遍历(因此stack和queue没有迭代器),只需要在固定的一端或者两端进行操作。
  2. 在stack中元素增长时,deque比vector的效率高(扩容时不需要搬移大量数据);queue中的元素增长
    时,deque不仅效率高,而且内存使用率高

结合了deque的优点,而完美的避开了其缺陷。

总结

这次学习了容器适配器——stack和queue,了解到用容器作为模板的美妙与神奇,极大简化构建容器的代码量。同时简单了解deque的结构和使用场景,进一步理解STL容器的设计。


真诚点赞,手有余香

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

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

基于JavaWeb实现的网上订餐系统

一、系统架构 前端&#xff1a;jsp | bootstrap | js | css 后端&#xff1a;servlet | jdbc 环境&#xff1a;jdk1.6 | mysql | tomcat | maven 二、 代码及数据库 三、功能介绍 01. 登录页 02. 首页1 03. 首页2 04. 首页3 05. 关于我们 06. 我的购物车…

抖音视频批量下载软件|视频评论采集工具

抖音视频评论采集软件是一款基于C#开发的高效、便捷的工具&#xff0c;旨在为用户提供全面的数据采集和分析服务。用户可以通过关键词搜索抓取视频数据&#xff0c;也可以通过分享链接进行单个视频的抓取和下载&#xff0c;从而轻松获取抖音视频评论数据。 批量视频提取模块&a…

NR 2-STEP RA Absolute Timing Advance Command MAC CE的应用场景

3 GPP在 R2-2002413中将2-step RA引入&#xff0c;进而R16 38.321出现了 Absolute TAC MAC CE&#xff0c;在 NR Timing Advance(TA)_ntn rrc-CSDN博客 有提到这个MAC CE&#xff0c;当时以“absolute timing advance command MAC CE 在2-step RA的某个场景下使用”一笔带过&am…

安全运营中心(SOC)综合指南

什么是安全运营中心&#xff08;SOC&#xff09; 安全运营中心&#xff0c;也称为信息安全运营中心 &#xff08;ISOC&#xff09;&#xff0c;是结构良好的网络安全战略的核心。安全运营中心是一个集中式枢纽&#xff0c;无论是在组织内部还是外包&#xff0c;都致力于对整个…

‘grafana.ini‘ is read only ‘defaults.ini‘ is read only

docker安装grafana 关闭匿名登录情况下的免密登录遇到问题 grafana.ini is read only defaults.ini is read only 参考回答&#xff08;Grafana.ini giving me the creeps - #2 by bartweemaels - Configuration - Grafana Labs Community Forums&#xff09; 正确启动脚本 …

高质量信息源!对着监控34声爸爸,听不得呀!——早读(爬取热门微信文章解读)

高质量的信息源你知道哪些&#xff1f; 引言Python 代码第一篇 人民日报 夜读 真正的自律就是做好这两件事第二篇 人民日报 对着监控&#xff0c;他喊了34声“爸爸”&#xff01;网友&#xff1a;当爹的看不了这个第三篇&#xff08;跳&#xff09; 人民日报 来了&#xff01;新…

c语言经典测试题4

1.题1 #include <stdio.h>//没有break的话&#xff0c;输入什么都会往下一直执行下去&#xff0c;而且default在最后就会全都执行 int main() {char c;int v0 0, v1 0, v2 0;do{switch (c getchar())// 输入ADescriptor{casea:caseA:casee:caseE:casei:caseI:caseo:…

Unity的相机跟随和第三人称视角

Unity相机跟随和第三人称视角 介绍镜头视角跟随人物方向进行旋转的镜头视角固定球和人的镜头视角 思路跟随人物方向进行旋转的镜头视角固定球和人的镜头视角 镜头旋转代码人物移动的参考代码注意 介绍 最近足球项目的镜头在做改动&#xff0c;观察了一下实况足球的视角&#x…

读《Shape-Guided: Shape-Guided Dual-Memory Learning for 3D Anomaly Detection》

Chu Y M, Chieh L, Hsieh T I, et al. Shape-Guided Dual-Memory Learning for 3D Anomaly Detection[J]. 2023.&#xff08;为毛paperwithcode上面曾经的榜一引用却只有1&#xff09; 摘要 专家学习 无监督 第一个专家&#xff1a;局部几何&#xff0c;距离建模 第二个专家&…

项目解决方案:海外门店视频汇聚方案(全球性的连锁店、国外连锁店视频接入和汇聚方案)

目 录 一、概述 二、建设目标及需求 2.1 建设目标 2.2 需求描述 2.3 需求分析 三、建设方案设计 3.1 系统方案拓扑图 3.2 方案描述 3.3 服务器配置推荐 四、产品功能 4.1 资源管理平台 &#xff08;1&#xff09;用户权限管理 &#xff08;2&#xff09…

K8S之Deployment的介绍和使用

Deployment的理论和实操 Deployment控制器&#xff1a;概念、原理解读概述工作原理 编写Deployment资源清单文件使用案例&#xff1a;创建一个web站点Deployment管理pod&#xff1a;扩容、缩容通过deployment管理应用&#xff0c;实现扩容&#xff0c;把副本数变成3通过deploym…

软件开发大体流程

1.开发流程 2.角色分工 3.软件环境

Qt中tableView控件的使用

tableView使用注意事项 tableView在使用时&#xff0c;从工具栏拖动到底层页面后&#xff0c;右键进行选择如下图所示&#xff1a; 此处需要注意的是&#xff0c;需要去修改属性&#xff0c;从UI上修改属性如下所示&#xff1a; 也可以通过代码修改属性&#xff1a; //将其设…

Kafka安全模式之身份认证

一、简介 Kafka作为一个分布式的发布-订阅消息系统&#xff0c;在日常项目中被频繁使用&#xff0c;通常情况下无论是生产者还是消费者只要订阅Topic后&#xff0c;即可进行消息的发送和接收。而kafka在0.9.0.0版本后添加了身份认证和权限控制两种安全服务&#xff0c;本文主要…

微信小程序的医院体检预约管理系统springboot+uniapp+python

本系统设计的目的是建立一个简化信息管理工作、便于操作的体检导引平台。共有以下四个模块&#xff1a; uni-app框架&#xff1a;使用Vue.js开发跨平台应用的前端框架&#xff0c;编写一套代码&#xff0c;可编译到Android、小程序等平台。 语言&#xff1a;pythonjavanode.js…

第十四天-网络爬虫基础

1.什么是爬虫 1.爬虫&#xff08;又被称为网页蜘蛛&#xff0c;网络机器人&#xff09;&#xff0c;是按照一定规则&#xff0c;自动的抓取万维网中的程序或者脚本&#xff0c;是搜索引擎的重要组成&#xff1b;比如&#xff1a;百度、 2.爬虫应用&#xff1a;1.搜索引擎&…

Rust使用calamine读取excel文件,Rust使用rust_xlsxwriter写入excel文件

Rust使用calamine读取已存在的test.xlsx文件全部数据&#xff0c;还读取指定单元格数据&#xff1b;Rust使用rust_xlsxwriter创建新的output.xlsx文件&#xff0c;并写入数据到指定单元格&#xff0c;然后再保存工作簿。 Cargo.toml main.rs /*rust读取excel文件*/ use cala…

Linux下性能分析的可视化图表工具

1 sar 和sadf 1.1 简介 sar命令可以记录系统下的常见活动信息&#xff0c;例如CPU使用率、网络统计数据、Block I/O数据、内存使用情况 等。 sar命令的“-o [file_name]”参数可以将系统活动数据记录到file_name文件&#xff0c;然后通过sadf来解析&#xff0c;sadf命令的“-g…

【ArcGIS】基本概念-空间参考与变换

ArcGIS基本概念-空间参考与变换 1 空间参考与地图投影1.1 空间参考1.2 大地坐标系&#xff08;地理坐标系&#xff09;1.3 投影坐标系总结 2 投影变换预处理2.1 定义投影2.2 转换自定义地理&#xff08;坐标&#xff09;变换2.3 转换坐标记法 3 投影变换3.1 矢量数据的投影变换…

wayland(xdg_wm_base) + egl + opengles 使用 Assimp 加载3D model 最简实例(十三)

文章目录 前言一、3D model 文件介绍1. 3d model 介绍1.1 如何获取3d model 文件1.2 3d model 的文件格式1.3 obj模型数据格式2. 3d 立方体 model 实例——cube.obj二、Assimp 介绍1. Assimp 简介2.ubuntu 上安装libassimp3. 使用Assimp 解析 cube.obj 文件3.1 assimp_load_cub…