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对于适配器的选择,是有要求的。

相关推荐
汉克老师4 小时前
GESP2025年3月认证C++五级( 第二部分判断题(1-10))
c++·算法·分治算法·线性筛法·gesp5级·gesp五级
橙子也要努力变强4 小时前
volatile与信号
linux·服务器·c++
Shadow(⊙o⊙)5 小时前
智能指针、循环引用、锁、删除器
开发语言·c++·后端·visual studio
水云桐程序员5 小时前
C++官方文档获取平台
c++·学习方法
Sylvia-girl5 小时前
C++模板【上】
开发语言·c++
王老师青少年编程5 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:荷马史诗
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·荷马史诗
样例过了就是过了5 小时前
LeetCode热题100 最小路径和
c++·算法·leetcode·动态规划
迷途之人不知返6 小时前
Stack & Queue
c++·算法
(Charon)6 小时前
【C++/Qt】Qt 实现 MQTT 测试工具:连接 Broker、订阅主题与发布消息
开发语言·c++·qt