用队列实现栈-力扣

本题是使用队列来实现栈,在栈实现队列时,我们使用了输入栈和输出栈来调整输出顺序,但时队列不同,队列元素先入先出,即使使用两个队列,也没法调整到先入后出。因此做法是依次将队列元素出队,然后再让其入队,当出队元素是 最初的队列 最后一个元素时,它就是栈顶元素。代码如下:
在top()函数中,可以直接返回 que.back(),也能直接得到队列的最后一个元素。

class MyStack {
public:
    MyStack() {

    }
    
    void push(int x) {
        que.push(x);
    }
    
    int pop() {
        int size = que.size() - 1;
        while(size--){
            que.push(que.front());
            que.pop();
        }
        int result = que.front();
        que.pop();
        return result;
    }
    
    int top() {
        int result = this->pop();
        this->push(result);
        return result;
    }
    
    bool empty() {
        return que.empty();
    }
private:
    queue<int> que;
};

/**
 * 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. 225. 队列实现

    2024-06-06 00:16:09       50 阅读
  2. 232. 实现队列

    2024-06-06 00:16:09       51 阅读
  3. 队列实现-

    2024-06-06 00:16:09       30 阅读
  4. 每日一题 --- 实现队列[][Go]

    2024-06-06 00:16:09       37 阅读
  5. [题解]225. 队列实现

    2024-06-06 00:16:09       31 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-06 00:16:09       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-06 00:16:09       100 阅读
  3. 在Django里面运行非项目文件

    2024-06-06 00:16:09       82 阅读
  4. Python语言-面向对象

    2024-06-06 00:16:09       91 阅读

热门阅读

  1. 【git】常用命令

    2024-06-06 00:16:09       33 阅读
  2. Django 目录

    2024-06-06 00:16:09       28 阅读
  3. CMake是怎么找到Qt相关模块的

    2024-06-06 00:16:09       22 阅读
  4. 深入探讨Qt中的容器类:QList与QVector

    2024-06-06 00:16:09       32 阅读
  5. uniapp tab组件

    2024-06-06 00:16:09       27 阅读
  6. Linux 主机一键安全整改策略

    2024-06-06 00:16:09       31 阅读
  7. 机器学习-9-python中的pipeline以及sklearn中的pipeline

    2024-06-06 00:16:09       30 阅读
  8. 事务与并发控制

    2024-06-06 00:16:09       26 阅读
  9. 恶意代码详解

    2024-06-06 00:16:09       34 阅读