《面试题精选》16.双栈实现队列和双队列实现栈

题目:分别用两个栈实现一个队列,和两个队列实现一个栈

分析:

1> 两个栈实现一个队列:

首先我们还是老方法,举个少量数据的例子,从中发现规律。首先我们向其中一个栈中插入a,b,c。存入栈中的顺序就是c-b-a,此时我们如果进行dequeue操作的话,因为队列是先进先出,所以a是先出的,但如果我们直接对栈pop的话那么出来的就是c。所以我们要将栈1中的数据转移到栈2中,直到最后一个元素时则把它出栈。这样我们就完成了dequeue操作。

但是queue操作怎么办?比如我们要让e,f入队,还是跟前面的一样栈1是用来存数据的。

好吧,我们来理一下思路。栈1是用来存入队的元素,栈2是用来出队的,但出队之前要使得栈1为空。

class MyQueue<T>{

    Stack<T> stack1 ,stack2 ;

    public MyQueue(){
        stack1 = new Stack<T>() ;
        stack2 = new Stack<T>() ;
    }

    public void appendTail(T x){
        stack1.push(x) ;
    }

    public void deleteHead(){
        if(stack1.empty()){
           if(stack2.empty()) System.out.println("queue is empty!");
           else stack2.pop() ;
        }else{
            while(!stack1.empty()){
                stack2.push(stack1.pop()) ;
            }
            stack2.pop() ;
        }
    }
    public boolean isEmpty(){
        if(stack1.empty()&&stack2.empty()) return true ;
        else return false ;
    }
}

2> 两个队列实现一个栈

非空队列用来存数据,空队列用来存储从另一个队列中出队的数据。

如abc存入其中一个队列中,顺序为c-b-a,此时执行出栈操作的话,则将该队列中的元素移到空队列中,知道最后一个元素,则直接出队。当要插入e,f时则直接插入到非空队列中。

class MyStack<T>{
    PriorityQueue<T> queue1,queue2 ;

    public MyStack(){
        queue1 = new PriorityQueue<T>() ;
        queue2 = new PriorityQueue<T>() ;

    }
    public void push(T x){
        if(queue1.size()!=0) queue1.add(x) ;
        else queue2.add(x) ;
    }
    public void pop(){
        if(queue1.size()!=0){
            while(queue1.size()>1) queue2.add(queue1.poll()) ;
            queue1.poll() ;
        }else if(queue2.size()!=0){
            while(queue2.size()>1) queue1.add(queue2.poll()) ;
            queue2.poll() ;
        }else System.out.println("Stack is empty!") ;
    }
}
时间: 2024-10-06 17:10:53

《面试题精选》16.双栈实现队列和双队列实现栈的相关文章

&lt;2014 05 16&gt; 线性表、栈与队列——一个环形队列的C语言实现

栈与队列都是具有特殊存取方式的线性表,栈属于先进后出(FILO),而队列则是先进先出(FIFO).栈能够将递归问题转化为非递归问题,这是它的一个重要特性.除了FILO.FIFO这样的最普遍存取方式外,还有一些扩展的数据结构,如双端队列.双栈.超队列.超栈等,它们是一种扩展与变异结构. 线性表有顺序存储和链接存储两类,这是针对计算机的线性存储空间作出的分类.前者可以是数组,后者可以是链表.字符串是线性表最常见的应用. 这里我用C语言实现了一个基于数组环形队列,它具有固定的队列空间.相比于链表实现,

面试题9-用两个栈来实现一个队列,完成队列的Push和Pop操作

题目 用两个栈来实现一个队列,完成队列的Push和Pop操作. 队列中的元素为int类型. 思路: 一个栈压入元素,而另一个栈作为缓冲,将栈1的元素出栈后压入栈2中 代码 import java.util.Stack; /** *两个栈实现一个队列 * @author MSI */ public class Requeue{ Stack<Integer> sk1=new Stack<Integer>(); Stack<Integer> sk2=new Stack<

PHP双向队列,双端队列代码

<?php /**  * User: jifei  * Date: 2013-07-30  * Time: 23:12 */ /**  * PHP实现双向队列,双端队列  * 双端队列(deque,全名double-ended queue)是一种具有队列和栈性质的数据结构.  * 双端队列中的元素可以从两端弹出,插入和删除操作限定在队列的两边进行.  */ class Deque {     public $queue=array();     /**      * 构造函数初始化队列     

单调队列(双端队列) poj2823 hdoj3415 hdoj3530

单调队列及其应用(双端队列) 单调队列,望文生义,就是指队列中的元素是单调的.如:{a1,a2,a3,a4--an}满足a1<=a2<=a3--<=an,a序列便是单调递增序列.同理递减队列也是存在的. 单调队列的出现可以简化问题,队首元素便是最大(小)值,这样,选取最大(小)值的复杂度便为o(1),由于队列的性质,每个元素入队一次,出队一次,维护队列的复杂度均摊下来便是o(1). 如何维护单调队列呢,以单调递增序列为例: 1.如果队列的长度一定,先判断队首元素是否在规定范围内,如果超范

剑指offer (7) 两个栈实现队列 两个队列实现栈

题目:用两个栈实现一个队列. 队列的声明如下,请实现它的两个函数 appendTail 和  deleteHead,分别完成队列尾部插入结点 和 队列头部删除结点 AppendTail:直接将元素入栈stack1 DeleteHead:当stack2中不为空时,在stack2中的栈顶元素是最先进入队列的元素,可以弹出 如果stack2为空,我们把stack1中的元素逐个弹出并入栈stack2,由于先进入队列的元素被压到stack1的底端,经过弹栈和压入stack2之后就处于stack2的顶端 1

数据结构&amp;算法(一)_堆、栈(堆栈)、队列、链表

堆: ①堆通常是一个可以被看做一棵树的数组对象.堆总是满足下列性质: ·堆中某个节点的值总是不大于或不小于其父节点的值: ·堆总是一棵完全二叉树.将根节点最大的堆叫做最大堆或大根堆,根节点最小的堆叫做最小堆或小根堆.常见的堆有二叉堆.斐波那契堆等. ②堆是在程序运行时,而不是在程序编译时,申请某个大小的内存空间.即动态分配内存,对其访问和对一般内存的访问没有区别. ③堆是应用程序在运行的时候请求操作系统分配给自己内存,一般是申请/给予的过程. ④堆是指程序运行时申请的动态内存,而栈只是指一种使用

数据结构和算法之栈和队列一:两个栈模拟一个队列以及两个队列模拟一个栈

今天我们需要学习的是关于数据结构里面经常看到的两种结构,栈和队列.可以说我们是一直都在使用栈,比如说在前面递归所使用的的系统的栈,以及在链表倒序输出时介绍的自定义栈类Stack和使用系统的栈进行递归.那么,在这里我们就讲述一下这两个比较具有特色的或者说关系比较紧密的数据结构之间的互相实现问题. 一:两个栈模拟实现一个队列: 栈的特点是先进后出,然而队列的特点是先进先出. public class Queen(Stack s1,Stack s2){ //实现插入的方法 public void ad

从0开始学算法--数据结构(2.4双端队列与单调队列)

双端队列是特殊的队列,它与队列不同的是可以将元素加入头或尾,可以从头或尾取出元素(滑稽-这部就是栈和队列结合了吗). c++标准库 头文件 #include<deque> 定义 deque<int>deq; 取出队头,尾元素 deq.pop_front(); deq.pop_back(); 访问队头,尾元素 deq.front(); deq.back(); 向队头,尾加入元素 deq.push_front(x); deq.push_back(x); 单调队列是在队列的基础上使它保持

金三银四,磨砺锋芒;剑指大厂,扬帆起航(2020年最全大厂WEB前端面试题精选)下

金三银四,磨砺锋芒:剑指大厂,扬帆起航(2020年最全大厂WEB前端面试题精选)下 引言 元旦匆匆而过,2020年的春节又接踵而来,大家除了忙的提着裤子加班.年底冲冲冲外,还有着对于明年的迷茫和期待!2019年有多少苦涩心酸,2020年就有更多幸福美好,加油,奥利给!怀着一颗积极向上的心,来面对未来每一天的挑战! 所谓"兵马未动,粮草先行",我们打响明天的战役也需要精神食粮来做后勤保障才是.在此我整理了多位从业者和我在2019年底至2020年初的一厂面试精选题,希望对磨砺锋芒.奋发向上