0
点赞
收藏
分享

微信扫一扫

怎样用队列实现栈?怎样用栈实现队列?

一、栈

栈:先进后出。

方法功能
Stack()构造一个空的栈
E push(E e)将e入栈,并返回e
E pop()将栈顶元素出栈并返回
E peek()获取栈顶元素
int size()获取栈中有效元素个数
boolean empty()检测栈是否为空

二、队列

队列:先进先出。

方法功能
boolean offer(E e)入队列
E poll()出队列
peek()获取队头元素
int size()获取队列中有效元素个数
boolean isEmpty()检测队列是否为空

三、用队列实现栈

  • 解题思路

  • 代码
import java.util.*;

class MyStack {

    public Queue<Integer> qu1;
    public Queue<Integer> qu2;

    public MyStack() {
        this.qu1=new LinkedList<>();
        this.qu2=new LinkedList<>();
    }
    
    //将元素 x 压入栈顶
    public void push(int x) {
        if(!qu1.isEmpty()){
            qu1.offer(x);
        }else if(!qu2.isEmpty()){
            qu2.offer(x);
        }else{//都为空时
            qu1.offer(x);
        }
    }
    
    //移除并返回栈顶元素
    public int pop() {
        if(empty()){
            return -1;
        }
        if(!qu1.isEmpty()){
            int size=qu1.size();//循环中size一直在改变,需提前定义
            for(int i=0;i<size-1;i++){
                int x=qu1.poll();
                qu2.offer(x);
            }
            return qu1.poll();
        }else{
            int size=qu2.size();//循环中size一直在改变,需提前定义
            for(int i=0;i<size-1;i++){
                int x=qu2.poll();
                qu1.offer(x);
            }
            return qu2.poll();
        }
    }
    
    //返回栈顶元素
    public int top() {
        if(empty()){
            return -1;
        }
        if(!qu1.isEmpty()){
            int x=-1;
            int size=qu1.size();//循环中size一直在改变,需提前定义
            for(int i=0;i<size;i++){
                x=qu1.poll();
                qu2.offer(x);
            }
            return x;
        }else{
            int x=-1;
            int size=qu2.size();//循环中size一直在改变,需提前定义
            for(int i=0;i<size;i++) {
                x=qu2.poll();
                qu1.offer(x);
            }
            return x;
        }
    }
    
    //如果栈是空的,返回 true ;否则,返回 false
    public boolean empty() {
        return qu1.isEmpty()&&qu2.isEmpty();
    }

}

四、用栈实现队列

  • 解题思路

  • 代码
import java.util.*;

class MyQueue {

    public Stack<Integer> st1;
    public Stack<Integer> st2;

    public MyQueue() {
        this.st1=new Stack<>();
        this.st2=new Stack<>();
    }
    
    //将元素 x 推到队列的末尾
    public void push(int x) {
        st1.push(x);
    }
    
    //从队列的开头移除并返回元素
    public int pop() {
        if(empty()){
            return -1;
        }
        if(st2.empty()){
            while(!st1.empty()){
                int x=st1.pop();
                st2.push(x);
            }
        }
        return st2.pop();
    }
    
    //返回队列开头的元素
    public int peek() {
        if(empty()){
            return -1;
        }
        if(st2.empty()){
            while(!st1.empty()){
                int x=st1.pop();
                st2.push(x);
            }
        }
        return st2.peek();
    }
    
    //如果队列为空,返回 true ;否则,返回 false
    public boolean empty() {
        return st1.empty()&& st2.empty();
    }

}
举报

相关推荐

0 条评论