【leetcode】用栈实现队列

题目链接:232. 用栈实现队列 - 力扣(LeetCode)

栈虽是先进后出,用一个栈可以将序列倒序,那么再用一个栈就可以正序了

先用一个栈存储进来的,要输出的时候再用一个栈装一下

复制代码
class MyQueue {
public:
    stack<int> in;
    stack<int> out;

    void inToOut() {
        while (!in.empty()) {
            out.push(in.top());
            in.pop();
        }
    }

    MyQueue() {

    }

    void push(int x) {
        in.push(x);
    }

    int pop() {
        int top = peek();
        out.pop();
        return top;
    }

    int peek() {
        if (out.empty())
            inToOut();
        return out.top();
    }

    bool empty() {
        return in.empty() && out.empty();
    }
};
相关推荐
Lucky_ldy10 分钟前
C语言学习: 自定义类型—联合和枚举
c语言·学习·算法
gumichef10 分钟前
栈和队列(2)
数据结构·算法·链表
进击的荆棘12 分钟前
递归、搜索与回溯——综合(下)
c++·算法·leetcode·深度优先·dfs
不知名的忻13 分钟前
归并排序(Java)
java·算法·排序算法
YUDAMENGNIUBI3 小时前
day20_逻辑回归
算法·机器学习·逻辑回归
澈2077 小时前
C++并查集:高效解决连通性问题
java·c++·算法
旖-旎9 小时前
深搜练习(单词搜索)(12)
c++·算法·深度优先·力扣
企客宝CRM10 小时前
2026年中小企业CRM选型指南:企客宝CRM处于什么位置?
android·算法·企业微信·rxjava·crm
橙淮10 小时前
二叉树核心概念与Java实现详解
数据结构·算法
米罗篮10 小时前
DSU并查集 & 拓展欧几里得-逆元
c++·经验分享·笔记·算法·青少年编程