c/c++语言开发共享C++stack与queue模拟实现详解

目录stack与queue模拟实现 在stl中,stack(栈)与queue(队列)都是容器适配器。什么是容器适配器呢?适配器(adaptor)是标准库中通用的概念,包括容器适配器、迭代器适配器和函数

目录

stack与queue模拟实现

在stl中,stack(栈)与queue(队列)都是容器适配器。

什么是容器适配器呢?

适配器(adaptor)是标准库中通用的概念,包括容器适配器、迭代器适配器和函数适配器。本质上,适配器是使一事物的行为类似于另一事物的行为的一种机制。容器适配器让一种已存在的容器类型采用另一种不同的抽象类型的工作方式实现。简单来说其实就是利用现有的容器来适配出来的新容器。

stack

在标准库中,stack默认使用的是deque容器来进行适配的。
当然这里也可以适配vector容器和list容器。

  namespace zj  {  	//template<class t,class container= zj::list<t>>  	//template<class t,class container= zj::vector<t>>  	template<class t,class container= zj::deque<t>>  	class stack  	{  	public:  		void pop()  		{  			m_stack.pop_back();  		}  		void push(const t&val)  		{  			m_stack.push_back(val);  		}  		size_t size()	const  		{  			return static_cast<size_t>(m_stack.size());  		}  		t& top()	  		{  			return m_stack.back();  		}  		const t& top() const  		{  			return m_stack.back();  		}  		bool empty()	const  		{  			return m_stack.empty();  		}  	private:  		container m_stack;  	};  }  

queue

与stack一样,在标准库中默认使用的是deque容器来进行适配的。

  namespace zj  {  	template<class t,class container=zj::deque<t>>  	class queue  	{  	public:  		void pop()  		{  			m_queue.pop_front();  		}  		void push(const t& val)  		{  			m_queue.push_back(val);  		}  		size_t size()	const  		{  			return static_cast<size_t>(m_queue.size());  		}  		t& back()  		{  			return m_queue.back();  		}  		const t& back() const  		{  			return m_queue.back();  		}  		t& front()  		{  			return m_queue.front();  		}  		const t& front() const  		{  			return m_queue.front();  		}  		bool empty()	const  		{  			return m_queue.empty();  		}  	private:  		container m_queue;  	};  }  

为什么选择deque作为stack和queue的底层默认容器

stack是一种后进先出的特殊线性数据结构,因此只要具有push_back()和pop_back()操作的线性结构,都可以作为stack的底层容器,比如vector和list都可以;

queue是先进先出的特殊线性数据结构,只要具有push_back和pop_front操作的线性结构,都可以作为queue的底层容器,比如list。

但是stl中对stack和queue默认选择deque作为其底层容器,主要是因为:

1.stack和queue不需要遍历(因此stack和queue没有迭代器),只需要在固定的一端或者两端进行操作。

2.在stack中元素增长时,deque比vector的效率高(扩容时不需要搬移大量数据);queue中的元素增长时,deque不仅效率高,而且内存使用率高。

但是deque有一个致命缺陷:不适合遍历,特别是在遍历或者排序时,deque的迭代器要频繁的去检测其是否移动到某段小空间的边界,导致效率低下。

总结

本片文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注<计算机技术网(www.ctvol.com)!!>的更多内容!

需要了解更多c/c++开发分享C++stack与queue模拟实现详解,都可以关注C/C++技术分享栏目—计算机技术网(www.ctvol.com)!

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/c-cdevelopment/791173.html

(0)
上一篇 2021年9月9日
下一篇 2021年9月9日

精彩推荐