栈和队列的实现

用栈实现队列

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();
 */
相关推荐
404号扳手2 分钟前
Java 进阶知识(七)
java·后端
小马爱打代码10 分钟前
Spring框架:介绍和快速入门
java·后端·spring
糖果店的幽灵12 分钟前
LangChain 1.3 完全教程:从入门到精通-Part 7: Documents(文档处理)
java·python·langchain
Deep-w18 分钟前
【MATLAB】基于模型预测控制的自适应巡航车辆过渡工况安全控制研究
开发语言·人工智能·算法·机器学习·matlab
Java_2017_csdn18 分钟前
Java 策略模式(Strategy Pattern)-(三)
java·开发语言·servlet
欧米欧21 分钟前
C++进阶数据结构之红黑树
数据结构
许彰午23 分钟前
06_Java面向对象入门
java·开发语言·python
Java_2017_csdn24 分钟前
Java 策略模式(Strategy Pattern)-(二)
java·开发语言·策略模式
papership26 分钟前
【入门级-数据结构-1、线性结构:链 表(单链表、双向链表、循环链表 )】
数据结构·算法·链表
摇滚侠27 分钟前
CSDN AI 数字营销测评 营销组件
java