stack模拟实现比较简单,就是直接调用deque的函数即可。
具体实现:
#pragma once
#include<deque>
#include<iostream>
using std::istream;
using std::ostream;
using std::endl;
using std::cout;
namespace zyy
{
//stack -> 后进先出
template<class T, class Container = std::deque<T>>
class stack
{
public:
void push(const T& x)
{
_con.push_back(x);
}
void pop()
{
_con.pop_back();
}
T& top()
{
return _con.back();
}
const T& top() const
{
return _con.back();
}
size_t size() const
{
return _con.size();
}
bool empty() const
{
return _con.empty();
}
private:
Container _con;
};
};
测试:
#include "stack.h"
using namespace zyy;
void test1()
{
stack<int> st;
st.push(1);
st.push(2);
st.push(3);
st.push(4);
st.push(5);
cout << "栈顶元素: " << st.top() << endl;
cout << "st.size : " << st.size() << endl;
for (int i = 0; i < 5; ++i)
{
//cout << "i: " << i << " ";
cout << st.top() << " ";
st.pop();
}
cout << endl;
}
int main()
{
test1();
return 0;
}
测试结果: