C++模拟实现stack

C++模拟实现stack

🌟🌟hello,各位读者大大们你们好呀🌟🌟

🚀🚀系列专栏:【C++的学习】

📝📝本篇内容:stack的基本概念;stack的基本结构;size()成员函数;empty()成员函数;push()成员函数;pop()成员函数;top()成员函数;完整代码

⬆⬆⬆⬆上一篇:一文速通stack和queue的理解与使用

💖💖作者简介:轩情吖,请多多指教(> •̀֊•́ ) ̖́-

1.stack的基本概念

stack是一个容器适配器,它底层是修改其他容器的接口,形成另一种风貌。stack就是我们常说的数据结构栈,它具有先进后出的特性,我们只能对它的一端进行操作,并且stack不允许遍历

2.stack基本结构

cpp 复制代码
#define _CRT_SECURE_NO_WARNINGS 1
#pragma once
#include <iostream>
#include <deque>
using namespace std;
namespace lnb
{
//既然是模拟实现,我们默认的Container也可以是vector或list,可以更好的理解,deque是库中默认的
	template<class T, class Container = deque<T>>
	class stack
	{
	public:



	private:
		//修改其他容器的接口,形成另一种风貌:容器适配器
		Container _con;
	};
}

可以先去看一下vector和list的模拟实现,这样就可以很好的理解后面的内容了

3.size()成员函数

cpp 复制代码
		//有效元素个数
		size_t size()
		{
			return _con.size();
		}

直接使用底层容器的接口

4.empty()成员函数

cpp 复制代码
//判空
		bool empty()
		{
			return _con.empty();
		}

5.push()成员函数

cpp 复制代码
		//压栈
		void push(const T& val)
		{
			_con.push_back(val);
		}

6.pop()成员函数

cpp 复制代码
		//出栈
		void pop()
		{
			_con.pop_back();
		}

7.top()成员函数

cpp 复制代码
		//获取栈顶元素
		T& top()
		{
			return _con.back();
		}
		
		//针对const对象
		const T& top()const
		{
			return _con.back();
		}

8.完整代码

cpp 复制代码
#define _CRT_SECURE_NO_WARNINGS 1
#pragma once
#include <iostream>
#include <deque>
using namespace std;
namespace lnb
{
//既然是模拟实现,我们默认的Container也可以是vector或list,可以更好的理解,deque是库中默认的
	template<class T, class Container = deque<T>>
	class stack
	{
	public:
		//有效元素个数
		size_t size()
		{
			return _con.size();
		}
		
		//判空
		bool empty()
		{
			return _con.empty();
		}

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

		//出栈
		void pop()
		{
			_con.pop_back();
		}


		//获取栈顶元素
		T& top()
		{
			return _con.back();
		}
		
		//针对const对象
		const T& top()const
		{
			return _con.back();
		}

	private:
		//修改其他容器的接口,形成另一种风貌:容器适配器
		Container _con;
	};
}

其实stack的模拟实现很简单,只需要调用别的容器的接口即可,压根没有难度~
🌸🌸C++模拟实现stack的知识大概就讲到这里啦,博主后续会继续更新更多C++的相关知识,干货满满,如果觉得博主写的还不错的话,希望各位小伙伴不要吝啬手中的三连哦!你们的支持是博主坚持创作的动力!💪💪

相关推荐
赵侃侃爱分享25 分钟前
学完Python第一次写程序写了这个简单的计算器
开发语言·python
yolo_guo32 分钟前
glog单行 30000 字节限制问题
c++
断眉的派大星40 分钟前
# Python 魔术方法(魔法方法)超详细讲解
开发语言·python
2501_9333295543 分钟前
技术深度拆解:Infoseek舆情处置系统的全链路架构与核心实现
开发语言·人工智能·自然语言处理·架构
妮妮喔妮1 小时前
supabase的webhook报错
开发语言·前端·javascript
我的xiaodoujiao1 小时前
API 接口自动化测试详细图文教程学习系列11--Requests模块3--测试练习
开发语言·python·学习·测试工具·pytest
cccccc语言我来了1 小时前
C++轻量级消息队列服务器
java·服务器·c++
闻缺陷则喜何志丹1 小时前
【背包 组合】P7552 [COCI 2020/2021 #6] Anagramistica|普及+
c++·算法·背包·洛谷·组合
xiaoye-duck1 小时前
【C++:C++11】C++11新特性深度解析:从类新功能、Lambda表达式到包装器实战
开发语言·c++·c++11
qq_12084093711 小时前
Three.js 大场景分块加载实战:从全量渲染到可视集调度
开发语言·javascript·数码相机