【LeetCode】232. 用栈实现队列

题目

https://leetcode-cn.com/problems/implement-queue-using-stacks/

思路

用两个栈倒腾,让元素的顺序反转两次,就回到了原始顺序

  • stackIn是正常栈中顺序,stackOut是反转顺序
  • 每次push总是往stackIn里加
  • 每次pop/peek
    • 如果stackOut里面非空,那么在stackOutpop/peek
    • 如果stackOut里面为空而且stackIn不为空,那么就将stackIn中的全部元素直接pushstackOut

code

java 复制代码
class MyQueue {
    Deque<Integer> stackIn = new ArrayDeque<>();
    Deque<Integer> stackOut = new ArrayDeque<>();
    
    public MyQueue() {
        
    }
    
    public void push(int x) {
        stackIn.push(x);
    }
    
    public int pop() {
        if(empty()) return -1;
        if(!stackOut.isEmpty()){
            return stackOut.pop();
        }else{
            int count=stackIn.size();
            for(int i=0;i<count;i++){
                stackOut.push(stackIn.pop());
            }
            return stackOut.pop();
        }
        
    }
    
    public int peek() {
        if(empty()) return -1;
        if(!stackOut.isEmpty()){
            return stackOut.peek();
        }else{
            int count=stackIn.size();
            for(int i=0;i<count;i++){
                stackOut.push(stackIn.pop());
            }
            return stackOut.peek();
        }
        
    }
    
    public boolean empty() {
        return stackIn.isEmpty() && stackOut.isEmpty();
        
    }
}
相关推荐
人道领域2 小时前
【LeetCode刷题日记】142.环形链表Ⅱ
算法·leetcode·链表
2301_822703202 小时前
开源鸿蒙跨平台Flutter开发:基因序列比对基础:Needleman-Wunsch 算法的 Dart 实现
算法·flutter·开源·鸿蒙
Book思议-2 小时前
【数据结构】「树」专题:树、森林与二叉树遍历之间的关系+408真题
数据结构·算法·二叉树··森林
Fcy6482 小时前
算法基础详解(4)双指针算法
开发语言·算法·双指针
zk_ken2 小时前
优化图像拼接算法思路
算法
xwz小王子2 小时前
Nature Communications从结构到功能:基于Kresling折纸的多模态微型机器人设计
人工智能·算法·机器人
luj_17682 小时前
从R语言想起的,。。。
服务器·c语言·开发语言·经验分享·算法
白眼黑刺猬2 小时前
如何构建 Flink SQL 任务的血缘分析
大数据·面试·职场和发展·flink
计算机安禾2 小时前
【数据结构与算法】第29篇:红黑树原理与C语言模拟
c语言·开发语言·数据结构·c++·算法·visual studio