码迷,mamicode.com
首页 > 其他好文 > 详细

013使用两个栈实现一个队列(keep it up)

时间:2014-08-27 01:40:37      阅读:230      评论:0      收藏:0      [点我收藏+]

标签:c++   算法   数据结构   

使用两个栈实现一个队列
队列是先进先出的数据结构(FIFO),栈是先进后出的数据结构(FILO), 
用两个栈来实现队列的最简单方式是:进入队列则往第一个栈压栈, 
出队列则将第一个栈的数据依次压入第二个栈,然后出栈.
两条规则:
1)进队列,则直接压入第一个栈
2)出队列,若果第二个栈不为空,直接pop(),如过第二个栈为空,

则把第一个栈中的数据全部压入第二个栈(第一个栈此时为空)。

实际写代码时注意栈为空的情况。

代码:

#include <iostream>
#include <stack>

class Queue
{
public:
	Queue() {}
	~Queue() {}

	void push(int vData)
	{
		m_First.push(vData);
	}

	void pop()
	{
		if (m_Second.empty())
		{
			if (m_First.empty())
			{
				std::cout << "the queue is empty" << std::endl;
				return ;
			}
			move(m_First, m_Second);
			m_Second.pop();
		}
	}

	int top()
	{
		if (m_Second.empty())
		{
			if (m_First.empty())
			{
				std::cout << "the queue is empty" << std::endl;
				return ;
			}
			move(m_First, m_Second);
		}
		return m_Second.top();
	}

	int back()
	{
		if (m_First.empty())
		{
			if (m_Second.empty())
			{
				std::cout << "the queue is empty" << std::endl;
				return ;
			}
			move(m_Second, m_First);
		}
		return m_First.top();
	}

private:
	void move(std::stack<int>& vL, std::stack<int>& vR)
	{
		while (!vL.empty())
		{
			vR.push(vL.top());
			vL.pop();
		}
	}

private:
	std::stack<int> m_First;
	std::stack<int> m_Second;
};


013使用两个栈实现一个队列(keep it up)

标签:c++   算法   数据结构   

原文地址:http://blog.csdn.net/xiaoliangsky/article/details/38859647

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!