模拟实现stack类与queue类

这篇具有很好参考价值的文章主要介绍了模拟实现stack类与queue类。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言:

本章我们将学习stackqueue的基本使用以及模拟实现。与前面已经学过的容器不同,stackqueue属于STL六大组件之一的容器适配器范畴。

一.stack简介

STL中,stack是一个模板类,用于实现栈数据结构。栈是一种后进先出(LIFO)的数据结构,可以在栈顶进行插入和删除操作。

stack是一种容器适配器,容器适配器不是容器类型本身,而是对现有的容器类型进行了一定程度的封装和改造,从而形成了一种新的容器类型。

stack类封装了一个底层容器,可以使用多种不同的容器作为其底层实现,比如dequevector等。

stack的底层容器可以是任何标准的容器类模板或者一些其他特定的容器类,这些容器类应该支持以下操作:

  • empty:判空操作
  • back:获取尾部元素操作
  • push_back:尾部插入元素操作
  • pop_back:尾部删除元素操作

标准容器vectordequelist均符合这些需求,默认情况下,如果没有为stack指定特定的底层容器,默认情况下使用deque

至于deque是什么我们先不深究,我们就先把它看作vector一样,后面会讲到。

二.stack的模拟实现

我们已经知道栈是一个容器适配器,底层封装了其它容器,所以栈的实现非常简单,在实现各个函数接口时,我们直接复用封装的容器的相关接口即可。

不同于vectorlist的模拟实现,stack需要两个模板参数:

参数类型:class T
容器类型:class Container

我们可以在自己的命名空间中定义stack类,如下:

namespace dianxia
{
	template<class T, class Container = vector<T>>
	class stack
	{
	public:

		void push(const T& data)
		{
			//...
		}

		void pop()
		{
			//...
		}

		const T& top()
		{
			//...
		}

		size_t size()
		{
			//...
		}

		bool empty()
		{
			//...
		}

	private:
		Container _con;
	};
}

接下来就是实现各个接口了。作为容器适配器,stack的各接口实现极其简单,用一分钟实现一个栈来描述也不是太夸张,一起来看看吧。

namespace dianxia
{
	template<class T, class Container = vector<T>>
	class stack
	{

	public:

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

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

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

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

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

	private:
		Container _con;
	};

}

因为容器适配器是封装了一层容器的,所以可以直接调用底层容器的接口供自己使用。现在再回头看文章开头对于容器适配器的描述,应该能深刻理解了。

三.queue简介

queuestack非常相似。在STL中,队列(queue)是一种基本的数据结构,它是一种先进先出(FIFO)的数据结构。队列可以看作是一条通往某个目的地的等待队列,其中最先进入的元素首先被处理,而最后进入的元素则最后被处理。

stack相同,queue同样也是一个容器适配器queuestack对比起来学习会更加轻松。

四.queue模拟实现

queuestack的实现方式大同小异,此处不做赘述。

namespace dianxia
{
	template<class T, class Container = list<T>>
	class queue
	{
		void push()
		{
			_con.push_back();
		}

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

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

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

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

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

本章节的内容就到这里了。下一章我们将学习双端队列——deque和优先级队列——priority_queue,认识了双端队列,我们就能明白为什么库中的stackqueue要使用deque来做底层容器了。


本文到此结束,码文不易,还请多多支持哦!!!文章来源地址https://www.toymoban.com/news/detail-603363.html

到了这里,关于模拟实现stack类与queue类的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • [C++随笔录] stack && queue模拟实现

    🗨️stack的容器适配器应该选什么比较好呢? 首先, stack的特点是 头部入, 尾部出 ⇒ 尾插 和 尾删操作比较频繁 我们前面学过的容器有 vector 和 list, vector 和 list的尾插 和 尾删的时间复杂度是 O(1) , 还是适合做容器适配器的. stack的基本结构 用这个容器对象来进行模拟实现stac

    2024年02月06日
    浏览(31)
  • 【STL】stack、queue基本使用和模拟实现

    目录 前言 stack 接口介绍 模拟实现 queue 接口介绍 模拟实现 没有迭代器  deque介绍 stack 和 queue 本质上是一种容器配接器,就像我们平时充电时使用的电源适配器,能够将电压转换成设备能够接受的程度。 其通过封装特定容器作为其底层容器的类,通过一组特定的成员函数来

    2024年02月07日
    浏览(25)
  • 【C++】STL——stack和queue使用及模拟实现

    🚀 作者简介:一名在后端领域学习,并渴望能够学有所成的追梦人。 🚁 个人主页:不 良 🔥 系列专栏:🛸C++  🛹Linux 📕 学习格言:博观而约取,厚积而薄发 🌹 欢迎进来的小伙伴,如果小伙伴们在学习的过程中,发现有需要纠正的地方,烦请指正,希望能够与诸君一同

    2024年02月13日
    浏览(34)
  • [C++] STL_stack && queue接口的模拟实现

    stack的文档介绍 1. stack是一种容器适配器,专门用在具有 后进先出 操作的上下文环境中,其删除只能从容器的一端进行元素的插入与提取操作。 2. stack是作为容器适配器被实现的,容器适配器即是对特定类封装作为其底层的容器,并提供一组特定的成员函数来访问其元素,将

    2024年02月05日
    浏览(32)
  • C++:stack、queue、priority_queue增删查改模拟实现、deque底层原理

    我们先来看看 stack的相关接口有哪些: 从栈的接口,我们可以知道栈的接口是一种特殊的vector,所以我们完全可以使用vector来模拟实现stack。 因此我们可以将底层容器定义成模板,然后将容器类变量作为成员变量进行封装。在实现satck的各种接口时,通过成员变量来调用底层

    2024年02月03日
    浏览(34)
  • 【STL】容器适配器stack和queue常见用法及模拟实现

    1.stack介绍及使用 1.1 stack的介绍 stack文档介绍 stack是一种容器适配器,专门用在具有后进先出操作的上下文环境中,其删除只能从容器的一端进行元素的插入与提取操作。 stack是作为容器适配器被实现的,容器适配器是使用特定容器类的封装对象作为其基础容器的类,提供一

    2024年02月06日
    浏览(36)
  • 【C++】——栈和队列(stack、queue)及优先队列(priority_queue)的介绍和模拟实现

    今天我们来学习C++stl六大组件的其中一种,容器适配器,stack、queue及priority_queue都是容器适配器。我们循序渐进,接下来让我们先认识一下什么是容器适配器。 适配器是一种设计模式(设计模式是一套被反复使用的、多数人知晓的、经过分类编目的、代码设计经验的总结),该

    2024年02月08日
    浏览(34)
  • 【C++】STL中的容器适配器 stack queue 和 priority_queue 的模拟实现

    适配器是一种设计模式 (设计模式是一套被反复使用的、多数人知晓的、经过分类编目的、代码设计经验的总结),该种模式是将一个类的接口转换成客户希望的另外一个接口。 例如我们常见的充电器就是一种适配器,它将我们常用的220V交流电压转化为4,5V (或者其他更高的电

    2023年04月26日
    浏览(48)
  • 容器适配器---deque和STL ---stack queue priority_queue的模拟实现 C++

    目录 一、容器适配器 deque原理 deque的缺陷 deque的优势 二、stack的模拟实现  三、queue的模拟实现 四、优先级队列的模拟实现 适配器是一种设计模式(设计模式是一套被反复使用的、多数人知晓的、经过分类编目的、代码设计经验的总结),该种模式是将一个类的接口转换成客户

    2024年02月02日
    浏览(43)
  • C++初阶:容器适配器介绍、stack和queue常用接口详解及模拟实现

    介绍完了list类的相关内容后:C++初阶:适合新手的手撕list(模拟实现list) 接下来进入新的篇章,stack和queue的介绍以及模拟: stack是一种容器适配器,专门用在具有后进先出操作的上下文环境中,其删除只能从容器的一端进行元素的插入与提取操作。 stack是作为容器适配器

    2024年02月19日
    浏览(29)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包