zoukankan      html  css  js  c++  java
  • [Daily]利用两个栈实现队列

    【题目】

    • 编写一个类,用两个栈实现队列,支持队列的基本操作(enQueue、deQueue、peek)

    【分析】

    • 队列的访问规则是First In First Out;栈的访问规则是First In Last Out。
    • 用栈来模拟队的访问规则,核心思想就是:将入栈的顺序逆序,然后再出栈
    • 根据上面的核心思想,不难看出,我们可以使用两个栈,一个存储队列的入队顺序,一个存储队列的出队顺序
    • 入队栈和出队栈的关系:将入队栈的数据不断向出队栈入栈即可。(形象点就是一个杯子往另一个杯子倒东西,前一个杯子的上半部分跑到后一个杯子的下半部分去了,操作起逆序的作用
    • 当出队时,如果存储出队顺序的栈为空时,需要从入队栈更新数据。
    • 两个栈皆为空时,队列也为空。

    【实现】

    • 实现语言:C++
    • 源代码如下:
    /*由两个栈组成的队列*/
    #include<iostream>
    #include<stack>
    using namespace std;
    #define Error -1
    
    class TwoStacksQueue
    {
        private:
    	    stack<int> m_InputStack;        //专供入队的栈
    		stack<int> m_OutputStack;       //专供出队的栈
    		
    	public:
    	    void enQueue(int value)         //入队函数 
    		{
    			m_InputStack.push(value); 
    		} 
    		
    		int deQueue()                   //出队函数 
    		{
    			if(m_OutputStack.empty()&&m_InputStack.empty())
    			{
    				cout<<"此队列为空,操作无效!!"<<endl; 
    				return Error;
    			}
    			
    			InputToOutput();
    			int temp=m_OutputStack.top();
    			m_OutputStack.pop();
    			return temp;
    		}
    		
    		int peek()
    		{
    			if(m_OutputStack.empty()&&m_InputStack.empty())
    			{
    				cout<<"此队列为空,操作无效!!"<<endl; 
    				return Error;
    			}
    			
    			InputToOutput();
    			return m_OutputStack.top();
    		}
    	
    	private:
    		//当输出栈为空时,将输入栈的数据转到输出栈中 
    		void InputToOutput()
    		{
    			if(m_OutputStack.empty())
    			{
    				while(!m_InputStack.empty())
    				{
    					m_OutputStack.push(m_InputStack.top());
    					m_InputStack.pop();
    				}
    			}
    		}
    };
    
    
    int main()
    {
    	TwoStacksQueue queue;
    	queue.enQueue(1);
    	queue.enQueue(2);
    	queue.enQueue(3);
    	queue.enQueue(4);
    	cout<<queue.deQueue()<<endl; 
    	queue.enQueue(5);
    	cout<<"获取队首元素:"<<queue.peek()<<endl;
    	cout<<queue.deQueue()<<endl; 
    	cout<<queue.deQueue()<<endl; 
    	cout<<queue.deQueue()<<endl; 
    	cout<<queue.deQueue()<<endl; 
    } 
    
    • 控制台截图
  • 相关阅读:
    Hibernate实体对象三种状态
    tar命令: 对某目录文件打tar包时,排除指定的目录或文件
    开发项目时,提示 找不到类的解决方法,以及如何设置编译源目录
    当html中存在url中如: onclick="toView('参数1')", 参数1是特别字符,如&asop;&quot;' "等时,浏览器解析时会报错。解决方法如文中描述
    oracle表分区心得
    启动系统相关服务笔记整理
    使用PSD设计网页页面
    JAR、WAR、EAR 区别
    设置 MyEclipse 默认打开文件方式
    前端性能优化
  • 原文地址:https://www.cnblogs.com/ZhuSenlin/p/12381801.html
Copyright © 2011-2022 走看看