当前位置: 首页 > news >正文

[ C++ ] STL_stack(栈)queue(队列)使用及其重要接口模拟实现

本篇博文主要介绍C++ STL库中stack,queue的使用及其模拟实现,以及涉及到deque的介绍。

目录

1. stack

1.1 stack的介绍

1.2 stack使用及其模拟实现

1.2.1 stack() 

1.2.2 其他接口

2.queue

2.1 queue的介绍

2.2 queue使用及其模拟实现

2.2.1 queue()

 

2.2.2 其他接口及其模拟实现


1. stack

1.1 stack的介绍

stack官方文档介绍

1. stack 是一种容器适配器,专门用在具有 后进先出 操作的上下文环境中,其删除只能从容器的一端进行元素的插入与提取操作。
2. stack 是作为容器适配器被实现的,容器适配器即是对特定类封装作为其底层的容器,并提供一组特定的成员函数来访问其元素,将特定类作为其底层的,元素特定容器的尾部( 即栈顶 ) 被压入和弹出。
3. stack 的底层容器可以是任何标准的容器类模板或者一些其他特定的容器类,这些容器类应该支持以下操作:
        empty:判空操作
        back:获取尾部元素操作
        push_back:尾部插入元素操作
        pop_back:尾部删除元素操作
4. 标准容器 vector deque list 均符合这些需求,默认情况下, 如果没有为stack指定特定的底层容器,默认情况下使用deque。

1.2 stack使用及其模拟实现

函数说明
接口说明
stack()
构造空的栈

empty()

检测 stack 是否为空
size()
返回 stack 中元素的个数
top()
返回栈顶元素的引用
push()
将元素 val 压入 stack
pop()
stack 中尾部的元素弹出

1.2.1 stack() 

栈的构造,析构等默认成员函数不需要我们自己手动写,因为他是自定义类型,会自动调用默认成员函数。

1.2.2 其他接口

栈是deque容器适配器构造的一个对象,因此栈的相关接口都可以使用容器适配器的接口,其实是一层封装。

因此,这些接口的代码实现也都非常的简单了

namespace lxy
{
    //stack
	template<class T, class Container = deque<T>>
	class stack
	{
	public:
		void push(const T& x)
		{
			_con.push_back(x);
		}
		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;
	};

2.queue

2.1 queue的介绍

queue官方文档介绍

 

1. 队列是一种容器适配器,专门用于在 FIFO 上下文 (先进先出) 中操作,其中从容器一端插入元素,另一端提取元素。
2. 队列作为容器适配器实现,容器适配器即将特定容器类封装作为其底层容器类, queue 提供一组特定的成员函数来访问其元素。元素从队尾入队列,从队头出队列。
3. 底层容器可以是标准容器类模板之一,也可以是其他专门设计的容器类。该底层容器应至少支持以下操作:
        empty:检测队列是否为空
        size:返回队列中有效元素的个数
        front:返回队头元素的引用
        back:返回队尾元素的引用
        push_back:在队列尾部入队列
        pop_front:在队列头部出队列
4. 标准容器类 deque list 满足了这些要求。 默认情况下,如果没有为queue实例化指定容器类,则使用标准容器deque。

2.2 queue使用及其模拟实现

函数声明
接口说明
queue()
构造空的队列
empty()
检测队列是否为空,是返回 true ,否则返回 false
size()
返回队列中有效元素的个数
front()
返回队头元素的引用
back()
返回队尾元素的引用
push()
在队尾将元素 val 入队列
pop()
将队头元素出队列

2.2.1 queue()

与栈类似,会调用默认的成员函数

 

2.2.2 其他接口及其模拟实现

队列和栈的大逻辑正好相反,因此pop和push相关接口只需要反着调用即可,难度不大。

namespace lxy
{
	template<class T, class Container = deque<T>>
	class queue
	{
	public:
		void push(const T& x)
		{
			_con.push_back(x);
		}
		void pop()
		{
			_con.pop_front();
		}
		const T& front()
		{
			return _con.front();
		}
		const T& back()
		{
			return _con.back();
		}

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

(本篇完)

 

相关文章:

  • 【CSAPP】深入理解计算机系统 第九章 虚拟内存 动态链接 printf 17/26
  • 软文营销评论区怎样营造好的氛围?
  • Android Gradle plugin requires Java 11 问题解决
  • mysql安装,安装mysql配置教程(超级详细图解)
  • 为什么现在西红柿都“硬邦邦”的,放几个星期都不会坏?为你解答
  • java实现微信小程序获取手机号(htts接口实现)
  • 亚马逊,速卖通,国际站卖家为什么要做测评
  • Centos7搭建sftp服务器,开启SFTP上报日志
  • 模式识别课程混合式教学设计
  • 基于云原生的视频管理系统设计与实现
  • AOP的使用(详细讲解)
  • DES加密算法安全吗,有哪些优点和缺点?
  • AI智能分析网关包含哪些深度学习算法?如何赋能场景应用?
  • JavaEE图书管理项目
  • SpringBoot Web开发----Thymeleaf的简单入门
  • 《Java8实战》-第四章读书笔记(引入流Stream)
  • Angular 2 DI - IoC DI - 1
  • classpath对获取配置文件的影响
  • docker python 配置
  • iOS仿今日头条、壁纸应用、筛选分类、三方微博、颜色填充等源码
  • JAVA多线程机制解析-volatilesynchronized
  • Java深入 - 深入理解Java集合
  • k8s 面向应用开发者的基础命令
  • mongodb--安装和初步使用教程
  • node和express搭建代理服务器(源码)
  • PermissionScope Swift4 兼容问题
  • Python实现BT种子转化为磁力链接【实战】
  • React-生命周期杂记
  • SQL 难点解决:记录的引用
  • Unix命令
  • XForms - 更强大的Form
  • 从tcpdump抓包看TCP/IP协议
  • 对象引论
  • 模型微调
  • 前嗅ForeSpider中数据浏览界面介绍
  • 如何使用Mybatis第三方插件--PageHelper实现分页操作
  • 如何优雅的使用vue+Dcloud(Hbuild)开发混合app
  • 通过获取异步加载JS文件进度实现一个canvas环形loading图
  • 微信开源mars源码分析1—上层samples分析
  • 我与Jetbrains的这些年
  • 智能合约开发环境搭建及Hello World合约
  • TPG领衔财团投资轻奢珠宝品牌APM Monaco
  • ​LeetCode解法汇总1276. 不浪费原料的汉堡制作方案
  • ​决定德拉瓦州地区版图的关键历史事件
  • # linux 中使用 visudo 命令,怎么保存退出?
  • #pragma once
  • $().each和$.each的区别
  • (173)FPGA约束:单周期时序分析或默认时序分析
  • (JS基础)String 类型
  • (Mirage系列之二)VMware Horizon Mirage的经典用户用例及真实案例分析
  • (Spark3.2.0)Spark SQL 初探: 使用大数据分析2000万KF数据
  • (附表设计)不是我吹!超级全面的权限系统设计方案面世了
  • (附源码)spring boot基于Java的电影院售票与管理系统毕业设计 011449
  • (附源码)ssm航空客运订票系统 毕业设计 141612
  • (区间dp) (经典例题) 石子合并