前言
对于这两个容器适配器的模拟实现非常简单,因为stack和queue只是对其他容器的接口进行了包装,在STL中,若我们不指明用哪种容器作为底层实现,栈和队列都默认是又deque作为底层实现的。
也就是说,stack和queue不管是用哪种容器实现出来的,实际上定义出来的都是对容器进行了封装。
stack的模拟实现
所以我们知道了容器适配器实际上是对其他容器的封装之后,我们实现的时候就只需要调用底层容器的各个成员函数实现stack的接口就行:
成员函数及作用 | 模拟实现方法 |
push(元素入栈) | 调用指定容器的push_back |
pop(元素出栈) | 调用指定容器的pop_back |
top(获取栈顶元素) | 调用指定容器的back |
size(获取栈中有效元素个数) | 调用指定容器的size |
empty(判断栈是否为空) | 调用指定容器的empty |
swap(交换两个栈中的数据) | 调用指定容器的swap |
模拟实现的代码如下:
#pragma once
#include<queue>
#include<iostream>
using namespace std;
namespace CYF
{template<class T,class Container=std::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(){return _con.size();}bool empty(){return _con.empty();}void swap(stack<T,Container>& st){_con.swap(st._con);}private:Container _con;};
}
queue模拟实现
同样的我们也通过调用指定容器的成员函数来模拟实现queue。
成员函数及作用 | 模拟实现方法 |
---|---|
push(元素队尾入队) | 调用指定容器的push_back |
pop(元素队头出队) | 调用指定容器的pop_front |
front(获取队头元素) | 调用指定容器的front |
back(获取队尾元素) | 调用指定容器的back |
size(获取队列中有效数据个数) | 调用指定容器的size |
empty(判断队列是否为空) | 调用指定容器的empty |
swap(交换两个队列中的数据) | 调用指定容器的swap |
模拟实现的代码如下:
#pragma once
#include<iostream>
#include<list>
#include<queue>
using namespace std;namespace CYF
{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(){return _con.size();}bool empty(){return _con.empty();}void swap(queue<T,Container>& q){_con.swap(q._con);}private:Container _con;};
}
下面这是test.cpp中的测试代码:
#include"myStack.h"
#include"myQueue.h"
void test1()
{CYF::stack<int, vector<int>> st;st.push(1);st.push(2);st.push(3);st.push(4);while (!st.empty()){cout << st.top() << " ";st.pop();}cout << endl;
}void test2()
{CYF::queue<int, list<int>> q;q.push(1);q.push(2);q.push(3);q.push(4);while (!q.empty()){cout << q.front() << " ";q.pop();}cout << endl;
}int main()
{//test1();test2();return 0;
}
以上就是本篇的全部内容,谢谢大家!