栈和队列的实现

用栈实现队列

1.分析

2.代码

java 复制代码
class MyQueue {
      private Stack<Integer> s1;
      private Stack<Integer> s2;
    public MyQueue() {
      s1 = new Stack<>();
      s2 = new Stack<>();
    }
    
    public void push(int x) {
        s1.push(x);
    }
    
    public int pop() {
        if(empty()){
            return -1;
        }
        if(s2.empty()){
            while(!s1.empty()){
                s2.push(s1.pop());
            }
        }
       return s2.pop();
    }
    
    public int peek() {
         if(empty()){
            return -1;
        }
        if(s2.empty()){
            while(!s1.empty()){
                s2.push(s1.pop());
            }
        }
        return s2.peek();
    }
    
    public boolean empty() {
     return s1.empty()&&s2.empty();
    }
}

/**
 * Your MyQueue object will be instantiated and called as such:
 * MyQueue obj = new MyQueue();
 * obj.push(x);
 * int param_2 = obj.pop();
 * int param_3 = obj.peek();
 * boolean param_4 = obj.empty();
 */
相关推荐
The_SkyUzi6 小时前
【无标题】
java·maven
dllmayday6 小时前
Qt/QML + C++ 双向数据绑定(MVVM 模式的几种常用方法(ChatGPT)
开发语言·c++·qt
han_hanker7 小时前
统一拦截异常 @RestControllerAdvice
java·开发语言·数据库
liu****7 小时前
一.脚手架介绍以及部分工具使用
开发语言·数据结构·c++·手脚架开发
资深web全栈开发7 小时前
深入理解 Google Wire:Go 语言的编译时依赖注入框架
开发语言·后端·golang
忘记9267 小时前
什么是spring boot
java·spring boot·后端
ohoy7 小时前
EasyPoi 数据脱敏
开发语言·python·excel
Hello World呀7 小时前
Java实现手机号和身份证号脱敏工具类
java·开发语言
曹牧7 小时前
Java:serialVersionUID
java·开发语言
ekprada7 小时前
DAY36 复习日
开发语言·python·机器学习