代码随想录算法训练营第10天|232.用栈实现队列,225. 用队列实现栈

简介: 代码随想录算法训练营第10天|232.用栈实现队列,225. 用队列实现栈

理论基础

image.png

栈存储结构

又称为堆栈,是一种先入后出的数据结构。c++中的栈常用的接口如下:

  • pop(); 将顶部元素弹出;
  • push(x);将元素x放入栈的顶部;
  • top();返回栈的顶部元素;
  • size(); 返回栈的大小;
  • empty();返回队列是否为空的状态;

队列

image.png

队列存储结构

是一种先入先出的数据结构。c++中队列的常用接口如下:

  • front();返回队列头部元素;
  • back();返回队列尾部元素;
  • pop();将队列头部元素移除;
  • size();返回队列大小;
  • empty();返回队列是否为空的状态;

https://juejin.cn/post/6854573217269415950


232.用栈实现队列

代码:

class MyQueue {
private:
    stack<int> stIn;
    stack<int> stOut;   
public:
    MyQueue() {
    }
    void push(int x) {
        stIn.push(x);
    }
    int pop() {
        while(stOut.empty()){
            while(!stIn.empty()){
                stOut.push(stIn.top());
                stIn.pop();
            }
        }
        int val = stOut.top();
        stOut.pop();
        return val;
    }
    int peek() {
        int val = this->pop();
        stOut.push(val);
        return val;
    }
    bool empty() {
        return stIn.empty() && stOut.empty();
    }
};
/**
 * Your MyQueue object will be instantiated and called as such:
 * MyQueue* obj = new MyQueue();
 * obj->push(x);
 * int param_2 = obj->pop();
 * int param_3 = obj->peek();
 * bool param_4 = obj->empty();
 */

思路:

题目中队列需要实现的操作有:push(x), pop() , peek() , empty()。

栈只具备先入后出的属性,而队列是先入先出。所以可以利用两个栈来灵活的移动数据(一个用于存储刚push的数据,而一个用于存储需要被弹出的数据。)从而实现队列先入先出的属性。

难点:

pop()的实现是本题的难点所在,需要注意的点是只有当需要stOut为空时才需要将push进的元素全部放入stOut,否则实现的队列结构就不是先入先出了。

总结:

本题不涉及复杂的算法,主要用于认识与了解队列这种数据哦结构。

225. 用队列实现栈

代码:

class MyStack {
private:
    queue<int> queue1;
public:
    MyStack() {
    }
    void push(int x) {
        queue1.push(x);
    }
    int pop() {
        int size = queue1.size()-1;
        while(size--){
            queue1.push(queue1.front());
            queue1.pop();
        }
        int val = queue1.front();
        queue1.pop();
        return val;
    }
    int top() {
        return queue1.back();
    }
    bool empty() {
       return  queue1.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();
 */

思路:

题目栈需要实现的操作有:push(x), pop() , top() , empty()。

同样地,两种数据结构的属性不一样。可以利用队列的先入先出属性循环地遍历插入和弹出数据,从而实现栈所具备的属性。

难点:

本题难点用样的在于pop()的实现。pop()需要弹出并且返回最后一个push的数据。可以循环插入队列头部元素,同时弹出头部元素,一直重复,直到尾部元素被移动到了队列头部。在将元素pop就可以了。

总结:

本题的目的在于了解什么是队列,具备哪些属性。不涉及复杂的算法。


参考资料

代码随想录

栈:C++ stack(STL stack)用法详解

队列:什么是队列,队列及其应用(超详细)

堆:什么是堆?看这一篇就够了! - 掘金

相关文章
|
6天前
|
机器学习/深度学习 存储 算法
近端策略优化(PPO)算法的理论基础与PyTorch代码详解
近端策略优化(PPO)是深度强化学习中高效的策略优化方法,广泛应用于大语言模型的RLHF训练。PPO通过引入策略更新约束机制,平衡了更新幅度,提升了训练稳定性。其核心思想是在优势演员-评论家方法的基础上,采用裁剪和非裁剪项组成的替代目标函数,限制策略比率在[1-ϵ, 1+ϵ]区间内,防止过大的策略更新。本文详细探讨了PPO的基本原理、损失函数设计及PyTorch实现流程,提供了完整的代码示例。
114 10
近端策略优化(PPO)算法的理论基础与PyTorch代码详解
|
2月前
|
算法
【算法】栈
栈相关算法题,供参考,附有链接地址及板书
|
2月前
|
存储 算法 程序员
C 语言递归算法:以简洁代码驾驭复杂逻辑
C语言递归算法简介:通过简洁的代码实现复杂的逻辑处理,递归函数自我调用解决分层问题,高效而优雅。适用于树形结构遍历、数学计算等领域。
|
3月前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
99 1
|
3月前
|
存储 缓存 算法
通过优化算法和代码结构来提升易语言程序的执行效率
通过优化算法和代码结构来提升易语言程序的执行效率
|
4天前
|
算法 数据安全/隐私保护 计算机视觉
基于FPGA的图像双线性插值算法verilog实现,包括tb测试文件和MATLAB辅助验证
本项目展示了256×256图像通过双线性插值放大至512×512的效果,无水印展示。使用Matlab 2022a和Vivado 2019.2开发,提供完整代码及详细中文注释、操作视频。核心程序实现图像缩放,并在Matlab中验证效果。双线性插值算法通过FPGA高效实现图像缩放,确保质量。
|
1月前
|
算法 数据安全/隐私保护 计算机视觉
基于Retinex算法的图像去雾matlab仿真
本项目展示了基于Retinex算法的图像去雾技术。完整程序运行效果无水印,使用Matlab2022a开发。核心代码包含详细中文注释和操作步骤视频。Retinex理论由Edwin Land提出,旨在分离图像的光照和反射分量,增强图像对比度、颜色和细节,尤其在雾天条件下表现优异,有效解决图像去雾问题。
|
1月前
|
算法 数据可视化 安全
基于DWA优化算法的机器人路径规划matlab仿真
本项目基于DWA优化算法实现机器人路径规划的MATLAB仿真,适用于动态环境下的自主导航。使用MATLAB2022A版本运行,展示路径规划和预测结果。核心代码通过散点图和轨迹图可视化路径点及预测路径。DWA算法通过定义速度空间、采样候选动作并评估其优劣(目标方向性、障碍物距离、速度一致性),实时调整机器人运动参数,确保安全避障并接近目标。
148 68
|
3天前
|
算法
基于SOA海鸥优化算法的三维曲面最高点搜索matlab仿真
本程序基于海鸥优化算法(SOA)进行三维曲面最高点搜索的MATLAB仿真,输出收敛曲线和搜索结果。使用MATLAB2022A版本运行,核心代码实现种群初始化、适应度计算、交叉变异等操作。SOA模拟海鸥觅食行为,通过搜索飞行、跟随飞行和掠食飞行三种策略高效探索解空间,找到全局最优解。
|
1月前
|
算法 数据安全/隐私保护
室内障碍物射线追踪算法matlab模拟仿真
### 简介 本项目展示了室内障碍物射线追踪算法在无线通信中的应用。通过Matlab 2022a实现,包含完整程序运行效果(无水印),支持增加发射点和室内墙壁设置。核心代码配有详细中文注释及操作视频。该算法基于几何光学原理,模拟信号在复杂室内环境中的传播路径与强度,涵盖场景建模、射线发射、传播及接收点场强计算等步骤,为无线网络规划提供重要依据。

热门文章

最新文章