思路:
入队:
只将栈s1作为入队。
出队:
将栈s2作为出队,如果栈s1不为空,s2为空,出队时将s1的元素倒入s2中,再pop();
否则s2不为空,出队时直接在栈s2中pop();
#include<iostream>
#include<stack>
#include<assert.h>
using namespace std;
template<class T>
class Queue
{
public:
Queue()
:_size(0)
{}
void appendTail(T num)
{
s1.push(num);
_size++;
}
void deleteHead()
{
assert(_size>0);
if(s2.empty())
{
while(s1.size()!=1)
{
s2.push(s1.top());
s1.pop();
}
s1.pop();
}
else
{
s2.pop();
}
_size--;
}
T& top()
{
assert(_size>0);
if(s2.empty())
{
while(s1.size()!=1)
{
s2.push(s1.top());
}
return s1.top();
}
else
{
return s2.top();
}
}
private:
stack<T> s1;
stack<T> s2;
int _size;
};
int main()
{
Queue<int> q;
q.appendTail(1);
q.appendTail(2);
q.appendTail(3);
q.appendTail(4);
q.deleteHead();
q.deleteHead();
q.deleteHead();
q.deleteHead();
q.appendTail(5);
cout<<q.top()<<endl;
system("pause");
return 0;
}
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。