C++实现stack与queue数据结构的模拟

 更新时间:2023年04月19日 09:04:36   作者:芒果再努力  
stack是一种容器适配器,专门用在具有后进先出操作的上下文环境中,其删除只能从容器的一端进行 元素的插入与提取操作;队列是一种容器适配器,专门用于在FIFO上下文(先进先出)中操作,其中从容器一端插入元素,另一端提取元素

栈和队列都是容器适配器搞出来的,对容器进行封装,从而实现先进先出和后进先出的结构

stack模拟实现

常规实现数据结构的思路

template<class T>
class stack
{
public:
	//....
private:
	T* _a;
	size_t _size;
	size_t _capacity;
};

使用容器适配器:

**栈的容器适配器Container 可以使用vector list deque(双端队列) , 这些容器都必须支持尾插和尾删接口 push_back 和 pop_back, **stack的默认容器适配器使用deque

#pragma once
#include<iostream>
#include<deque>
using namespace std;
//栈的容量适配器Container 可以使用vector list deque-双端队列 
//必须支持尾插和尾删 push_back  和 pop_back
//默认的容量适配器使用deque
//  template<class T,class Container = std::vector<T>>
//  template<class T,class Container = std::list<T>>
namespace Mango
{
template<class T, class Container = std::deque<T>>
class stack
{
public:
	void push(const T& x)
		_con.push_back(x);
	void pop()
		_con.pop_back();
	//返回栈顶元素 - 即容器的最后一个元素
	T top()
		return _con.back();
	size_t size()
		return _con.size();
	bool empty()
		return _con.empty();
private:
	Container _con;//容器适配器
};
}

设配的容器给成模板参数->我有默认的容器适配器,你也可以自己定义合适的,对容器进行封装,达到后进先出的效果

queue模拟实现

队列的容器适配器Container 必须支持pop_front 和push_back函数 尾插和头删.

所以可以使用list 和deque, 但是不能使用vector,因为不支持头删pop_front函数

queue默认的容器适配器使用deque

#pragma once
#include<iostream>
#include<deque>
using namespace std;
// 队列的容器适配器Container 必须支持pop_front 和push_back  尾插和头删
// 所以可以使用list 和deque
// 但是不能使用vector,因为不支持头删pop_front
//默认的容量适配器使用deque
namespace Mango
{
template<class T, class Container = std::deque<T>>
class queue
{
public:
	//尾插
	void push()
		_con.push_back();
	//头删
	void pop()
		_con.pop_front();
	//取队头数据 -返回队头数据的引用
	T& front()
		return _con.front();
	//取队尾数据 -返回队尾数据的引用 
	T& back()
		return _con.back();
	size_t size()
		return _con.size();
	bool empty()
		return _con.empty();
private:
	Container _con;//容量适配器
};
}

到此这篇关于C++实现stack与queue数据结构的模拟的文章就介绍到这了,更多相关C++ stack与queue模拟内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 使用C++进行Cocos2d-x游戏开发入门过程中的要点解析

    使用C++进行Cocos2d-x游戏开发入门过程中的要点解析

    这篇文章主要介绍了使用C++进行Cocos2d-x游戏开发入门过程中的要点解析,主要针对画面变化以及触摸响应方面,需要的朋友可以参考下
    2015-12-12
  • 浅析c语言中的内存

    浅析c语言中的内存

    在c++中,内存分为5个区,分别是栈区,堆区,自由存储区,全局/静态存储区和常量存储区.
    2017-09-09
  • C语言return, exit, abort的区别

    C语言return, exit, abort的区别

    这篇文章主要介绍了C语言return, exit, abort的区别,一般情况下,在C语言中退出一个程序用return,如果在main函数中,return在清理局部对象之后,会调用exit函数,和return相比,exit并不会销毁局部对象,下面一起进入文章了解更详细内容吧,需要的朋友也可以参考一下
    2022-01-01
  • 非常经典的C语言趣味题目

    非常经典的C语言趣味题目

    在这个网站上发现一套很有趣的C语言测试题,如果你招聘C语言相关开发人员,或者正在学习C语言,很值得做一做
    2013-04-04
  • 基于Qt开发一个简单的OFD阅读器

    基于Qt开发一个简单的OFD阅读器

    这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下
    2025-01-01
  • C语言八皇后问题解决方法示例【暴力法与回溯法】

    C语言八皇后问题解决方法示例【暴力法与回溯法】

    这篇文章主要介绍了C语言八皇后问题解决方法,简单描述了八皇后问题并结合实例形式分析了C语言基于暴力法与回溯法解决八皇后的具体操作技巧,需要的朋友可以参考下
    2018-01-01
  • stl常用算法(Algorithms)介绍(stl排序算法、非变序型队列)

    stl常用算法(Algorithms)介绍(stl排序算法、非变序型队列)

    这篇文章主要介绍了stl常用算法(Algorithms)介绍(stl排序算法、非变序型队列),需要的朋友可以参考下
    2014-05-05
  • C语言实现合式公式的判断示例

    C语言实现合式公式的判断示例

    这篇文章主要介绍了C语言实现合式公式的判断示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-04-04
  • 深入理解C++中的new和delete并实现对象池

    深入理解C++中的new和delete并实现对象池

    这篇文章主要介绍了C++中的new和delete并实现对象池,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-09-09
  • 基于C++的拼多多算法在线笔试题示例

    基于C++的拼多多算法在线笔试题示例

    这篇文章主要介绍了基于C++的拼多多算法在线笔试题,列举了四个拼多多的算法笔试题,包括分治法、大数相乘、贪心算法以及迷宫问题,需要的朋友可以参考下
    2017-08-08

最新评论