算法通关:014_1:用栈实现队列

文章目录

题目

用栈实现队列 leetcode :232

总结

时间复杂度

平均下来每个方式是O(1)

代码

java 复制代码
 class MyQueue {
        public Stack<Integer> in;
        public Stack<Integer> out;

        //初始化
        public MyQueue() {
            in = new Stack<>();
            out = new Stack<>();
        }

        //倒数据
        //从in栈 倒入 out栈
            //out栈为空才能倒数据
            //in栈有数据才能倒,且必须全部倒入out栈
        private void inToOut(){
            if(out.empty()){
                while(!in.empty()){//不是空就一直倒
                    out.push(in.pop());//从in里弹出的数据进入out
                }
            }
        }

        //加入数据
        public void push(int x){
            in.push(x);
            inToOut();//加入一个数据你看能不能倒数据,能就倒,不能就啥也不做
        }

        //弹出一个数
        public int pop(){
            inToOut();
            return out.pop();
        }

        //不弹出,返回队列头部
        public int peek(){
           inToOut();
           return out.peek();
        }
        //判空
        public boolean empty(){
            return in.isEmpty() && out.isEmpty();
        }

    }

运行结果

相关推荐
爪洼传承人几秒前
AI工具MCP的配置,慢sql优化
android·数据库·sql
范什么特西2 分钟前
idea创建一个普通的Maven项目运行javaweb
java·maven·intellij-idea
学习使我健康5 分钟前
MVP模式
android·github·软件工程
好家伙VCC8 分钟前
# 发散创新:用 Rust实现高性能物理引擎的底层架构设计与实战在游戏开发、虚拟仿真和机器人控
java·开发语言·python·rust·机器人
六道对穿肠8 分钟前
Java 直连 USB 打印机实战:从 JNI 崩溃到「拷贝即用」的架构演进
java
user_admin_god19 分钟前
OpenCode入门到入坑
java·人工智能·spring boot·语言模型
Maiko Star19 分钟前
Claude Code安装教程
java·chatgpt·claude code
Tina学编程23 分钟前
[HOT 100]今日一练------划分字母区间
算法·hot 100
RTC老炮25 分钟前
RaptorQ前向纠错算法架构分析
网络·算法·架构·webrtc
故事和你9125 分钟前
洛谷-数据结构1-1-线性表2
开发语言·数据结构·算法·动态规划·图论