您的位置:首页 > 其它

设计由两个栈组成的队列

2015-09-21 20:05 246 查看
//设计由两个栈组成的队列

//编写一个类,用两个栈实现队列,支持队列基本操作

//需要注意的是在是实现时TailSt不空时,不能对它Push操作,

#include <stack>

class myQueue

{

void Push(int x)

{

FrontSt.push(x);

}

int Top()

{

if (!TailSt.empty())

return TailSt.top();

else

{

while (!FrontSt.empty())

{

TailSt.push(FrontSt.top());

FrontSt.pop();

}

return TailSt.top();

}

}

void Pop()

{

if (TailSt.empty() && FrontSt.empty())

return;

if (TailSt.empty() && !FrontSt.empty())

{

while (!FrontSt.empty())

{

TailSt.push(FrontSt.top());

FrontSt.pop();

}

}

TailSt.pop();

}

private:

stack<int> FrontSt; //用于队尾

stack<int> TailSt; //用于队头

};
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: