栈和队列的实现

用栈实现队列

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();
 */
相关推荐
元清加油2 分钟前
【Golang】:函数和包
服务器·开发语言·网络·后端·网络协议·golang
健康平安的活着41 分钟前
java之 junit4单元测试Mockito的使用
java·开发语言·单元测试
Java小白程序员1 小时前
Spring Framework :IoC 容器的原理与实践
java·后端·spring
xuTao6672 小时前
Easy Rules 规则引擎详解
java·easy rules
DjangoJason2 小时前
C++ 仿RabbitMQ实现消息队列项目
开发语言·c++·rabbitmq
m0_480502642 小时前
Rust 入门 KV存储HashMap (十七)
java·开发语言·rust
大阳1233 小时前
线程(基本概念和相关命令)
开发语言·数据结构·经验分享·算法·线程·学习经验
杨DaB3 小时前
【SpringBoot】Swagger 接口工具
java·spring boot·后端·restful·swagger
YA3333 小时前
java基础(九)sql基础及索引
java·开发语言·sql
桦说编程3 小时前
方法一定要有返回值 \ o /
java·后端·函数式编程