【STL】queue,stack的底层实现

在前面的介绍中我们已经知道了queue和stack是一个容器适配器,它并没有被划分到容器的行列,它只是对其他容器的再封装,在STL中queue和stack默认使用的容器是deque

在数据结构的学习中,我们知道stack和queue可以使用顺序表和链表实现,若我们在这里定义一个vector让stack进行包装实现,实际上就是stack中的每个接口的实现都复用了vector的接口

Stack的模拟实现

stack接口:

|-------|-----------|------------------|
| 成员函数 | 函数功能 | 实现方法 |
| push | 元素入栈 | 调用指定容器的push_back |
| pop | 元素出栈 | 调用指定容器的pop_back |
| top | 获取栈顶元素 | 调用指定容器的back |
| size | 获取栈中元素个数 | 调用指定容器的front |
| empty | 判断栈中是否有元素 | 调用指容器的empty |
| swap | 交换两个栈的数据 | 调用指定容器的swap |

模拟实现:

cpp 复制代码
template<class T, class container>
class stack
{
public:
	void push(const T& s)
	{
		return _con.push_back(s);
	}

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

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

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

	bool empty()
	{
		return _con.empty();
	}

	void swap(stack<T, container>& s)
	{
		_con.swap(s);
	}
private:
	container _con;
};

Queue的模拟实现

queue接口:

|-------|----------|-----------------|
| 成员函数 | 函数功能 | 实现方法 |
| push | 元素入队列 | 调用指定容器push_back |
| pop | 删除队头元素 | 调用指定容器pop_back |
| front | 获取队头元素 | 调用指定容器front |
| back | 获取队尾元素 | 调用指定容器back |
| size | 获取有效元素个数 | 调用指定容器size |
| empty | 判断队列是否为空 | 调用指定容器empty |
| swap | 交换两个队列元素 | 调用指定容器swap |

cpp 复制代码
template<class T, class container = deque<T>>
class queue
{
public:

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

	void pop()
	{
		_con.erase(_con.begin());
	}
	
	T& front()
	{
		return _con.front();
	}

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

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

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

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

	bool empty()
	{
		return _con.empty();
	}

	void swap(queue<T, container>& Q)
	{
		_con.swap(Q);
	}
private:
	container _con;
};

以上就完成了对stack和queue的实现,很简单

相关推荐
良木生香2 分钟前
【C++初阶】C++入门相关知识(2):输入输出 & 缺省参数 & 函数重载
开发语言·c++
小此方3 分钟前
Re:从零开始的 C++ 进阶篇(三)彻底搞懂 C++ 多态:虚函数、虚表与动态绑定的底层原理
c++
忘梓.4 分钟前
墨色规则与血色节点:C++红黑树设计与实现探秘
java·开发语言·c++
hhh3u3u3u4 分钟前
Visual C++ 6.0中文版安装包下载教程及win11安装教程
java·c语言·开发语言·c++·python·c#·vc-1
凤年徐6 分钟前
C++手撕红黑树:从0到200行,拿下STL map底层核心
c++·后端·算法
星河耀银海7 分钟前
C++ 模板进阶:特化、萃取与可变参数模板
java·开发语言·c++
cccccc语言我来了11 分钟前
【C++---unordered_set/map底层封装】个不拘一格的集合。它不似有序集合那般循规蹈矩,而是以一种洒脱不羁的方式,将元素们随意地散落其中。每一个元素都是独一无二的。
开发语言·c++·哈希算法
Zfox_11 分钟前
C++ IO流全解析:标准库中的数据处理与文件读写艺术
开发语言·c++
加号311 分钟前
【C#】实现沃德普线光控制器通信控制(附完整源码)
开发语言·c#
tankeven32 分钟前
动态规划专题(03):区间动态规划从原理到实践(未完待续)
c++·算法·动态规划