leetcode232:栈实现队列

栈实现队列

请你仅使用两个栈实现先入先出队列。队列应当支持一般队列支持的所有操作(pushpoppeekempty):

实现 MyQueue 类:

  • void push(int x) 将元素 x 推到队列的末尾
  • int pop() 从队列的开头移除并返回元素
  • int peek() 返回队列开头的元素
  • boolean empty() 如果队列为空,返回 true ;否则,返回 false
java 复制代码
class MyQueue {
        Stack<Integer> stack = new Stack<>();

        Stack<Integer> tmp = new Stack<>();

        public MyQueue() {

        }

        public void push(int x) {
            stack.push(x);
        }

        public int pop() {
            tmp.empty();
            while(!stack.empty()){
                tmp.push(stack.peek());
                stack.pop();
            }
            Integer res = tmp.pop();
            while(!tmp.empty()){
                stack.push(tmp.peek());
                tmp.pop();
            }
            return res;
        }

        public int peek() {
            tmp.empty();
            while(!stack.empty()){
                tmp.push(stack.peek());
                stack.pop();
            }
            Integer res = tmp.peek();
            while(!tmp.empty()){
                stack.push(tmp.peek());
                tmp.pop();
            }
            return res;
        }

        public boolean empty() {
            return stack.empty();
        }
    }

用另一个栈实现

相关推荐
春日见3 分钟前
端到端自动驾驶综述
linux·人工智能·算法·机器学习·自动驾驶
Book思议-23 分钟前
【数据结构实战】单向循环单链表判别条件理解
c语言·数据结构·算法
逆境不可逃28 分钟前
【后端新手谈 04】Spring 依赖注入所有方式 + 构造器注入成官方推荐的原因
java·开发语言·spring boot·后端·算法·spring·注入方式
森林里的程序猿猿32 分钟前
垃圾收集器ParNew&CMS与底层标记三色标记算法
java·jvm·算法
进击的小头33 分钟前
第12篇:开环系统伯德图设计控制器
python·算法
weixin_4588726137 分钟前
东华复试OJ二刷复盘13
数据结构·算法
TechPioneer_lp37 分钟前
腾讯客户端开发岗位 LeetCode 高频题汇总(2026版)
算法·leetcode·面试·求职招聘·笔试·腾讯校招·leetcode高频题
夏日听雨眠39 分钟前
数据结构1
数据结构·算法
jing-ya41 分钟前
day 55 图论part7
java·数据结构·算法·图论
我爱我家88243 分钟前
亚洲艺术电影节携澳门文化亮相深圳
人工智能·物联网·算法·区块链·爬山算法