力扣225.用队列实现栈

原题链接:力扣225.用队列实现栈

思路:主要就是用队列模拟栈的操作

需要注意的点就是栈和队列数据结构的区别

栈是先进后出,队列是先进先出

也就代表如果队列要模拟栈,就要对队列实现移动元素位置的操作,这个要注意

全代码:

cpp 复制代码
class MyStack {
public:
    MyStack() {

    }

    void push(int x) {// 将元素 x 压入栈顶。用单队列实现
    
        queuea.push(x);//将x先压入队列尾
        int len = queuea.size()-1;//获取队列总长度,但是减去1,因为移位置不需要移动刚添加进来的x
        while (len--) {//将队列头的元素逐步添加到队列尾,就成了旧元素不变,的以新元素x开头的队列
            queuea.push(queuea.front());
            queuea.pop();
        }
    }

    int pop() {//移除并返回栈顶元素
        if (!queuea.empty()) {
            //得到队列最先出的一个元素
            int a = queuea.front();
            //弹出
            queuea.pop();
            //返回弹出的元素
            return a;
        }
        else {//为空返回NULL
            return NULL;
        }
    }
    int top() {//返回栈顶元素。
        int a = queuea.front();
        return a;
    }
    bool empty() {//判断是否为空,空返回true,不为空返回false
        return queuea.empty();
    }
private:
    queue<int> queuea;
};
相关推荐
油泼刀削面7 分钟前
[控制理论]—带死区的PID控制算法及仿真
算法
金创想33 分钟前
十大排序简介
算法·排序算法·十大排序
执着的小火车1 小时前
【2024华为OD-E卷-100分-boss的收入】(题目+思路+Java&C++&Python解析)
数据结构·算法·华为od·华为·排序算法
終不似少年遊*1 小时前
机器学习模型评估指标
人工智能·算法·机器学习·回归·模型评价
剁椒排骨1 小时前
冒泡排序(C语言)
c语言·算法·排序算法·算法与结构
code04号2 小时前
图论:三维搜索
算法·图论
code04号2 小时前
图论:Tarjan算法的使用,找连通分量、割点、桥
算法·图论
ExRoc2 小时前
蓝桥杯真题 - 魔法阵 - 题解
c++·算法·蓝桥杯
夜泉_ly3 小时前
算法 -归并排序
算法
玖石书3 小时前
[c++]Linux平台下的动态库加载技术详解
linux·c++·算法