stack和queue的学习与模拟实现

stack & queue

1、学习stack & queue

stack遵循的规则:LIFO(后进先出)。

stack的常用接口非常简单,我们早在"数据结构"专栏中就已经见过了类似的接口。

stack是不支持迭代器的,否则就无法保证严格的后进先出。

queue遵循的规则:FIFO(先进先出)。

queue同样不支持迭代器。

2、模拟实现stack & queue

2.1、模拟实现stack

我们之前在数据结构的学习中,模拟实现stack使用的是数组,那么我们这里模拟实现stack,是否可以对vector进行封装呢?

确实是可以的。但是有更好的方法:适配器

我们的手机,通过电源适配器,可以连接充电宝、车载电源、家用电源进行充电。

那么stack,也可以通过适配器(vector、list等数据结构),以实现各种方法。

cpp 复制代码
// stack.h
#include<iostream>
#include<vector>
#include<list>
#include<deque>

using namespace std;

namespace yzc 
{
	template<class T, class Container = deque<T>>
	class stack
	{
	public:

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

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

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

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

		bool empty() { return size() == 0; }

	private:
		Container _con;
	};
}

vector作底层:

list做底层:

2.2、模拟实现queue

queue也可以使用适配器实现:

cpp 复制代码
// queue.h
#include<iostream>
#include<vector>
#include<list>
#include<deque>

using namespace std;

namespace yzc
{
	template<class T, class Container = deque<T>>
	class queue
	{
	public:

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

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

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

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

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

		bool empty() { return size() == 0; }

	private:
		Container _con;
	};
}

deque作底层:

list作底层:

但是vector作底层就不行:

因为vector并没有实现头删方法:

也就意味着,queue对于适配器的选择,是有要求的。

相关推荐
小小de风呀5 分钟前
de风——【从零开始学C++】(九)—vector的基本使用
开发语言·c++
L_090712 分钟前
【C++】数据结构之哈希表(散列表)
数据结构·c++·散列表
LB211219 分钟前
C++通讯录课设(西安石油大学)
开发语言·c++·算法
王老师青少年编程20 分钟前
2026年全国青少年信息素养大赛初赛真题(算法应用主题赛C++初中组初赛真题1:文末附答案和解析)
c++·真题·全国青少年信息素养大赛·初赛·2026年·算法应用主题赛·初中组
草莓熊Lotso2 小时前
【Linux系统加餐】从原理到封装:基于建造者模式实现System V信号量工业级C++封装
android·linux·运维·服务器·网络·c++·建造者模式
kyle~10 小时前
机器视觉---熔池相机(穿透强光的视觉感知)
c++·数码相机·计算机视觉·机器人·焊接机器人
宏笋10 小时前
C++ Coroutines(协程) 详解
c++
王老师青少年编程10 小时前
csp信奥赛C++高频考点专项训练之前缀和&差分 --【一维前缀和】:求区间和
c++·前缀和·csp·高频考点·信奥赛·求和区间和
kyle~11 小时前
机器人时间链路---工程流程示例
c++·3d·机器人·ros2
汉克老师12 小时前
GESP6级C++考试语法知识(十七、数据结构(三、认识队列 Queue))
数据结构·c++·队列·gesp6级·gesp六级·数组模拟队列