【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();
    }
};
相关推荐
王老师青少年编程几秒前
csp信奥赛C++之摩尔投票算法详解
数据结构·c++·算法·题解·csp·信奥赛·摩尔投票算法
Purple Coder9 分钟前
基于GNN的超导材料生长方法研究算法的实现-1
算法
tod11311 分钟前
C++ 核心知识点全解析(六)
c++·算法·面试经验
紫陌涵光13 分钟前
701. 二叉搜索树中的插入操作
算法·leetcode
tankeven15 分钟前
HJ100 等差数列
c++·算法
ADDDDDD_Trouvaille16 分钟前
2026.2.22——OJ98-100题
c++·算法
tankeven21 分钟前
HJ99 自守数
c++·算法
一只理智恩26 分钟前
基于 CesiumJS + React + Go 实现三维无人机编队实时巡航可视化系统
前端·人工智能·算法·golang·无人机
菜鸡儿齐32 分钟前
leetcode-分割回文串
算法·leetcode·职场和发展
重生之我是Java开发战士35 分钟前
【优选算法】链表:两数相加,两两交换节点,重排链表,合并K个升序链表,K个一组反转链表
数据结构·算法·链表