STL源码刨析_stack _queue

news2025/1/10 16:40:55

目录

一. 介绍

1. stack 介绍

2. queue 介绍

二. 模拟实现

1. stack 模拟实现

2. queue 模拟实现

三. deque

1. deque 接口

2. 底层


一. 介绍

1. stack 介绍

stack(栈)是一种容器适配器,它提供了一种后进先出(LIFO)的数据结构。以下是关于stack的介绍:

  • 特点:stack是一种具有特定功能的容器,它只能通过顶部(或称为栈顶)进行元素的插入和删除操作。插入操作称为入栈(push),删除操作称为出栈(pop)。对stack的访问受到限制,只能访问栈顶的元素。
  • 使用容器:stack的实现通过在内部使用其他容器来存储元素。默认情况下,STL中的stack使用deque(双端队列)作为底层容器。也可以通过指定其他容器类型来创建自定义底层容器的stack。
  • 基本操作:除了入栈和出栈操作外,stack还提供了其他一些常用的操作,如访问栈顶元素(top)、判断栈是否为空(empty)以及获取栈的大小(size)。
  • 不支持随机访问:与向量(vector)和列表(list)等容器不同,stack不支持通过索引进行随机访问。只能访问栈顶元素,且只能进行入栈和出栈操作。
  • 适用性:stack通常用于一些需要后进先出操作的场景,如逆序遍历、回溯算法、函数调用堆栈等。由于其简洁性和固定操作的特性,在许多算法和数据结构中都能够发挥作用。

总体上,stack是一种功能简单而强大的容器适配器,可用于实现后进先出的数据结构。通过提供入栈、出栈、访问栈顶等操作,stack提供了一种方便且高效的方式来管理数据。

2. queue 介绍

queue(队列)是一种容器适配器,它提供了一种先进先出(FIFO)的数据结构。以下是关于queue的介绍:

  • 特点:queue是一种具有特定功能的容器,它在队尾进行元素的插入操作,而在队头进行元素的删除操作。插入操作称为入队(push),删除操作称为出队(pop)。队列中的元素按照先进先出的顺序进行处理。
  • 使用容器:queue的实现通过在内部使用其他容器来存储元素。默认情况下,STL中的queue使用deque(双端队列)作为底层容器。也可以通过指定其他容器类型来创建自定义底层容器的queue。
  • 基本操作:除了入队和出队操作外,queue还提供了其他一些常用的操作,如访问队头元素(front)、访问队尾元素(back)、判断队列是否为空(empty)以及获取队列的大小(size)。
  • 不支持随机访问:与向量(vector)和列表(list)等容器不同,queue不支持通过索引进行随机访问。只能访问队头和队尾的元素,且只能进行入队和出队操作。
  • 适用性:queue通常用于一些需要先进先出操作的场景,如任务调度、事件处理、缓冲区管理等。通过提供入队、出队、访问队头和队尾的操作,queue提供了一种方便且高效的方式来管理数据。

总体上,queue是一种功能简单而强大的容器适配器,可用于实现先进先出的数据结构。通过提供入队、出队、访问队头和队尾等操作,queue提供了一种方便且高效的方式来管理数据。

二. 模拟实现

我们的 stack 和 queue 都是适配器,所以我们实现就不用很麻烦,我们前面也写过 stack 和 queue,我们知道什么容器适合 stack 和 queue 那么我们这次就使用 vector 来适配 stack 使用 list 来适配 queue。

1. stack 模拟实现

这里我们模拟实现的逻辑就是复用,我们的 stack 的类里面有一个 vector 的对象,但是我们不一定使用 vector 我们还可以使用 list, 所以我们的 stack 的模板可以多传一个参数,来表示我们适配的容器时使用什么容器,然后我们可以复用我们容器的函数,例如我们的 stack 里面有一个 push 但是我们的 stack 只有一个入口和出口,还是后进先出的,所以我们使用的容器是 vector 的话,我们就可以使用 push_back 和 pop_back。

下面我们也就不一个一个介绍了,我们直接看代码~

    template<class T, class Container = vector<T>>
	class stack
	{
	public:
		stack() {};

		~stack() {};

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

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

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

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

		bool empty()
		{
			return _con.empty();
		}
	private:
		Container _con;
	};

2. queue 模拟实现

queue 和 stack 其实基本都是一样的,但是我们的 queue 的容器就不能使用 vector 了,其实并不是不能使用,而是使用 vector 的效率很低,因为我们的 vector 需要头删、尾插, 我们知道我们的 vector 的中间或者头部的插入删除都是很慢的,所以我们的 queue 可以使用 list ,我们下main还是直接看代码。

	template<class T, class Container = list<T>>
	class queue
	{
	public:
		queue() {};

		~queue() {};

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

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

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

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

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

		bool empty()
		{
			return _con.empty();
		}
	private:
		Container _con;
	};

模拟实现就完了~

三. deque

deque 是一个既可以随机插入删除,也可以支持随机访问的一个容器,但是我们经常宾补怎么使用它,我们的 deque 被作为 stack 和 queue 的默认容器,可是为什么选择 deque 呢?我们下面简单的了解一下 deque。

1. deque 接口

其他的接口我们就不看了,我们主要看一下这些接口 

 我们看到上面,我们的 deque 即提供了头插,头删,还有我们的 operator[],说明我们的 deque 的头插和头删的效率并不慢,而且还提供了我们的 operator[],说明我们的 deque 还支持随机访问,所以说它就是很适合做 stack 和 queue 的容器。

2. 底层

我们这里说一下它的底层,我们的 deque 的底层是一个一个连续的空间,而我们还有一个数组就是专门管理这些连续的空间,就像下面这样

然后我们头插就向最前面的那个数组插入,尾插就像后面的插入,如果满了,就扩容,到管理的那个数组里面在加一个指针,指向一块新的数组,总的来说 deque 是很复杂的,这么两句也说不清楚,但是 deque 其实并不是很重要,我们不需要掌握它,所以了解一下即可

源码在 码云 里面。 

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

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

相关文章

如何优化APP应用内的广告点击率?提升变现收益?

对于大部分广告主来说&#xff0c;广告点击率&#xff08;CTR&#xff09;越高越好&#xff0c;而点击率又与收益密切相关。如何优化点击率&#xff0c;让应用内的流量售卖收益最大化呢&#xff1f; 说到优化点击率&#xff0c;那么就一定要说说这个名词&#xff1a; 点击率&…

第五章 动态规划(一)——背包问题

文章目录 01背包问题完全背包多重背包分组背包背包练习题2. 01背包问题3. 完全背包问题4. 多重背包问题 I5. 多重背包问题 II9. 分组背包问题 01背包问题 n个物品&#xff0c;每个物品的体积为 v i v_i vi​&#xff0c;价值为 w i w_i wi​&#xff0c;每次只能选择一个物品放…

JavaScript的库——jquery

JavaScript的库——jquery 一、jQuery的hello 将代码写在一个闭包中 二、面试题&#xff1a; jQuery的ready函数和JavaScript的onload事件有什么区别&#xff1f; 是null&#xff0c;因为拿不到box&#xff0c;代码在后面&#xff0c;还没有执行。 所以需要将代码放在后面&am…

ControlNet新玩法!一键生成AI艺术二维码QR

AI绘画又又又又火出圈了&#xff01;这波来源于AI人所发掘的ControlNet for QR Code 话不多说&#xff0c;看看效果图 这张看着极具个性的图像正是一个可以扫描的二维码&#xff0c;通过使用Stable Diffusion和Controlnet生成。由此定制生成个人艺术二维码&#xff0c;选择不同…

前端学习——JS进阶 (Day4)

深浅拷贝 练习 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" content"widthdevice…

Antd的Select组件二次封装

提示&#xff1a;Select组件二次封装的目的,是为了在系统里面更方便、简洁地使用Select 这是官方写的使用方法是: import React from react; import { Select } from antd;const handleChange (value: string) > {console.log(selected ${value}); };const App: React.FC …

信息泄露与大数据:隐私安全的挑战与对策

随着大数据时代的到来&#xff0c;我们生活的方方面面都与数据息息相关。然而&#xff0c;随之而来的信息泄露问题也日益严重&#xff0c;给个人隐私和数据安全带来了巨大挑战。本文将围绕信息泄露与大数据展开讨论&#xff0c;探讨其中的问题、原因以及如何应对。 山海鲸大屏 …

langchain +SQLDatabase+Mysql+OpenAI

通过langchain SQLDatabaseMysql来获取数据 参照:https://github.com/hwchase17/langchain/issues/2333 from langchain import OpenAI, SQLDatabase, SQLDatabaseChain from sqlalchemy import create_enginefrom common.keys import OPENAI_API_KEYengine create_engine(m…

Network Dissection 论文阅读笔记

Network Dissection 论文阅读笔记 1. 简介2. 网络刨析2.1 深度视觉表征的可解释性的测量步骤2.2 数据集2.3 可解释神经元评分 3. 实验3.1 对解释的人类评价3.2 Measurement of Axis-Aligned Interpretability3.3 理解层概念3.4 网络架构和监督3.5 训练条件 vs 可解释性3.6 网络…

【二等奖方案】基于人工智能的漏洞数据分类赛题「道可道,非常道」团队解题思路

2022 CCF BDCI 大赛 数字安全公开赛「基于人工智能的漏洞数据分类」赛题二等奖团队「道可道&#xff0c;非常道」战队获奖方案&#xff0c;赛题地址&#xff1a; http://go.datafountain.cn/s57 团队简介 本团队具有丰富的比赛和项目经验。在AI大赛上多次拿到Top成绩&#xf…

2.Docker镜像和容器操作

文章目录 Docker操作Docker镜像操作搜索镜像获取镜像镜像加速下载查看镜像详细信息为镜像添加标签删除镜像导出导入镜像上传镜像 Docker容器操作创建容器查看容器状态启动容器创建并启动容器进入容器停止容器删除容器复制容器文件到宿主机容器的导出导入 Docker操作 ###查看do…

uniapp中超好用(且免费)的安全类插件推荐!(持续更新中)

前几天写了一篇【干货分享】uniapp做的安卓App如何加固&#xff0c;发现收藏的人蛮多的。所以说&#xff0c;更加证明了我说的第一个问题&#xff1a;现在用uniapp的人是越来越多了。 而通过使用uniapp上自带的插件&#xff0c;也是能够实现事半功倍的效果&#xff0c;让不懂前…

简单记录一下剑指offer的编程题(C语言实现)——替换空格反转链表

1. 替换空格 (剑指 Offer 05) 请实现一个函数&#xff0c;把字符串 s 中的每个空格替换成"%20"。 示例&#xff1a; 输入&#xff1a;s "We are happy." 输出&#xff1a;"We%20are%20happy."简单分析&#xff1a; 新建一个数组&#xff0c;…

《SpringBoot篇》16.SpringBoot整合Elasticsearch

陈老老老板 说明&#xff1a;工作了&#xff0c;学习一些新的技术栈和工作中遇到的问题&#xff0c;边学习边总结&#xff0c;各位一起加油。需要注意的地方都标红了&#xff0c;还有资源的分享. 一起加油。 本文是介绍Elasticsearch用法与SpringBoot整合 1.ES简介 注&#xf…

Solus Linux 4.4版本发布

导读Solus Linux近日更新到4.4版本&#xff0c;作为这个受爱好者欢迎的Linux发行版的最新增量更新&#xff0c;团队仍在努力实现其基于Serpent OS和对Linux发行版的其他重大基本变化的纳入。 Solus 4.4带有各种各样的更新包&#xff0c;还有一些其他的改变&#xff0c;比如现在…

【C++学习记录】(二)--一个C++工程文件里有哪些东西?

写在前面 首先&#xff0c;我有一个完整的C工程文件&#xff0c;文件分别是包含Debug、include、Service和src。 1.了解文件结构: 首先&#xff0c;查看每个文件夹中的内容以了解文件的组织结构。Debug文件夹通常包含与调试相关的文件&#xff0c;include文件夹可能包含头文件…

Innovus:highlight clock tree(高亮时钟树方法)

过往文章链接&#xff1a; ICC2: highlight clock tree&#xff08;高亮时钟树方法&#xff09; innovus也有高亮clock tree的方法 在ccopt之后&#xff0c;使用ctd_win命令打开Clock Tree Debugger (CTD) window。 ctd_trace -from $root_pin -to $sink_pin -color $color ;#…

产品介绍|持续机器视觉产品的研发与迭代,赋能制造行业智慧生产

当前&#xff0c;以人工智能为代表的新一代信息技术正在加速推动社会各领域优化升级&#xff0c;对于行业自动化、智能化的要求越来越高&#xff0c;作为人工智能重要领域之一的机器视觉技术&#xff0c;迎来了快速发展。 机器视觉用机器代替人眼来做测量和判断&#xff0c;通…

STM32MP157驱动开发——设备树知识

文章目录 概述开发板中设备树文件目录结构设备树文件语法设备树文件参考实例&#xff1a;Devicetree 格式DTS 文件的格式node 的格式properties 的格式 dts 文件包含 dtsi 文件常用的属性#address-cells 、#size-cellscompatiblemodelstatusreginterruptgpio属性name( 过时了&a…

SSM框架整合

1.创建数据库表 数据库环境搭建 CREATE DATABASE ssmbuild;USE ssmbuildDROP TABLE IF EXISTS books;CREATE TABLE books( bookID INT(10) NOT NULL AUTO_INCREMENT COMMENT 书id, bookName VARCHAR(100) NOT NULL , bookCounts INT(11) NOT NULL , detail VARCHAR(200) NOT …