栈和队列的实现

用栈实现队列

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();
 */
相关推荐
共享家95271 小时前
链表操作:分区与回文判断
c语言·开发语言·数据结构·leetcode·链表
lx学习1 小时前
嵌入式c学习六
c语言·数据结构·学习
ClaNNEd@1 小时前
大话数据结构第二章,算法笔记
数据结构·笔记·算法
糖心何包蛋爱编程1 小时前
(二)Reactor核心-前置知识1
java·响应式编程·lambda表达式·干货分享
江沉晚呤时1 小时前
C#原型模式:通过克隆对象来优化创建过程
java·开发语言·microsoft·c#·asp.net·.netcore
苏墨瀚2 小时前
SQL语言的散点图
开发语言·后端·golang
飞翔中文网2 小时前
Java设计模式之装饰器模式
java·设计模式
Suwg2093 小时前
【Java导出word】使用poi-tl轻松实现Java导出数据到Word文档
java·开发语言·word·poi-tl
坚持拒绝熬夜3 小时前
JVM的一些知识
java·jvm·笔记·java-ee
水w3 小时前
【pyCharm Git】根据dev分支新建dev_y分支,本地也新建dev_y分支,并将代码提交到Gitlab上的新分支dev_y上。
开发语言·git·python·pycharm·pull·push·branch