143.栈和队列:用队列实现栈(力扣)

题目描述

代码解决

cpp 复制代码
class MyStack {
public:
    queue<int> que; // 定义一个队列用于实现栈

    // 构造函数,初始化队列
    MyStack() {}

    // 向栈中推入元素 x
    void push(int x) {
        que.push(x); // 使用队列的 push 方法将元素 x 添加到队列尾部
    }

    // 从栈中弹出并返回栈顶元素
    int pop() {
        int len = que.size(); // 获取队列的长度
        len--; // 因为我们要把最后一个元素弹出,所以只需要循环 len-1 次
        // 将队列中的前 len-1 个元素依次移到队列尾部
        while (len--) {
            que.push(que.front()); // 将队头元素添加到队尾
            que.pop(); // 弹出队头元素
        }
        int result = que.front(); // 获取此时队头元素,即栈顶元素
        que.pop(); // 弹出队头元素
        return result; // 返回栈顶元素
    }

    // 获取栈顶元素
    int top() {
        return que.back(); // 返回队列的最后一个元素,即栈顶元素
    }

    // 检查栈是否为空
    bool empty() {
        return que.empty(); // 返回队列是否为空
    }
};

/**
 * Your MyStack object will be instantiated and called as such:
 * MyStack* obj = new MyStack();
 * obj->push(x);
 * int param_2 = obj->pop();
 * int param_3 = obj->top();
 * bool param_4 = obj->empty();
 */
  1. MyStack有一个私有成员变量que,这是一个队列,用于存储栈的元素。

  2. 构造函数MyStack()没有参数,它只是初始化了队列que

  3. push(int x)方法用于将元素x推入栈。它使用队列的push方法将元素x添加到队列尾部。

  4. pop()方法用于从栈中弹出并返回栈顶元素。首先,它获取队列的长度,然后将队列中的前len-1个元素依次移到队列尾部。最后,它返回此时队列头部的元素,即栈顶元素。

  5. top()方法用于获取栈顶元素。它返回队列的最后一个元素,即栈顶元素。

  6. empty()方法用于检查栈是否为空。它返回队列是否为空的布尔值。

相关推荐
代码AI弗森1 小时前
一文理清楚“算力申请 / 成本测算 / 并发评估”
java·服务器·数据库
Old Uncle Tom2 小时前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
会编程的土豆2 小时前
洛谷题单入门1 顺序结构
数据结构·算法·golang
小小小米粒2 小时前
Collection单列集合、Map(Key - Value)双列集合,多继承实现。
java·开发语言·windows
生信碱移2 小时前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
智者知已应修善业2 小时前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机
摇滚侠2 小时前
expdp 查看帮助
java·数据库·oracle
:1213 小时前
java基础
java·开发语言
圣保罗的大教堂3 小时前
leetcode 1855. 下标对中的最大距离 中等
leetcode
曹牧4 小时前
Spring:@RequestMapping注解,匹配的顺序与上下文无关
java·后端·spring