栈和队列的实现

用栈实现队列

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();
 */
相关推荐
weixin_464307632 分钟前
QT智能指针
java·数据库·qt
沐知全栈开发4 分钟前
PHP Math: 精通PHP中的数学函数与应用
开发语言
架构师沉默5 分钟前
程序员如何避免猝死?
java·后端·架构
吴声子夜歌15 分钟前
JavaScript——call()、apply()和bind()
开发语言·前端·javascript
平凡灵感码头18 分钟前
C语言 printf 数据打印格式速查表
c语言·开发语言·算法
Zzxy25 分钟前
快速搭建SpringBoot项目并整合MyBatis-Plus
java·spring boot
星如雨グッ!(๑•̀ㅂ•́)و✧29 分钟前
WebFlux onErrorContinue 和 onErrorResume使用详解
java·人工智能
x_xbx30 分钟前
LeetCode:1. 两数之和
数据结构·算法·leetcode
电商API&Tina35 分钟前
电商数据采集API接口||合规优先、稳定高效、数据精准
java·javascript·数据库·python·json
玲娜贝儿--努力学习买大鸡腿版1 小时前
hot 100 刷题记录(1)
数据结构·python·算法