当前位置: 首页 > article >正文

stack和queue专题

文章目录

  • stack
    • 最小栈
      • 题目解析
      • 代码
    • 栈的压入弹出序列
      • 题目解析
      • 代码
  • queue
    • 二叉树的层序遍历
      • 题目解析
      • 代码

stack

stack和queue都是空间适配器

在这里插入图片描述

最小栈

最小栈的题目链接

在这里插入图片描述

题目解析

  • minst是空就进栈,或者是val <= minst.top()就进栈
    在这里插入图片描述

代码

class MinStack {
public:
    MinStack() {
        
    }
    
    void push(int val) 
    {
        st.push(val);
        if(minst.empty() || val <= minst.top())
        {
            minst.push(val);
        }
    }
    
    void pop() 
    {
        if(st.top() == minst.top())
        {
            minst.pop();
        }    
        st.pop();
    }
    
    int top() 
    {
        return st.top();    
    }
    
    int getMin() 
    {
       return minst.top();    
    }
private:
    stack<int> st;
    stack<int> minst;
};

栈的压入弹出序列

栈的压入弹出序列

在这里插入图片描述

题目解析

1.入栈序列入栈一个值(一个一个地入栈)
2.栈顶元素跟出栈序列是否匹配,持续出
3.不匹配看入栈是否已经入完了,没有入完继续入,入完了就结束了

在这里插入图片描述

代码

class Solution 
{
public:
    bool IsPopOrder(vector<int>& pushV, vector<int>& popV) 
    {
        size_t popi = 0;
        stack<int> st;
        for(auto& ch : pushV)
        {
            // 入栈
            st.push(ch);
            
            // 入栈和出栈元素匹配
            // 栈不为空取栈顶元素,一种特殊情况
            // 1,2,3,4,5  4,3,2,1,5
            // 栈会为空,不加!st.empty(),会崩溃
            // 持续出栈
            while(!st.empty() && st.top() == popV[popi])
            {
                st.pop();
                ++popi;
            }
        }
        // 如果栈为空就返回true,都出完了
        // 如果栈为假就返回false,popV出不了了,就不匹配
        return st.empty();
    }
};

queue

在这里插入图片描述

二叉树的层序遍历

二叉树的层序遍历

在这里插入图片描述

题目解析

根节点出队列,把根节点的孩子入队列
1.设置一个变量记录当前层的节点个数
2.一层一层出,队列的size就是当前层的size
因为出一个节点就把它的孩子带入,只有它的孩子在队列中,所以队列的size就是当前层的levelSize

在这里插入图片描述

代码

class Solution 
{
public:
    vector<vector<int>> levelOrder(TreeNode* root) 
    {
        vector<vector<int>> vv;
        queue<TreeNode*> q;
        size_t levelSize = 0;
        if(root)
        {
            q.push(root);
            levelSize = 1;
        }

        while(!q.empty())
        {
            vector<int> v;
            while(levelSize--)
            {
                TreeNode* front = q.front();
                v.push_back(front->val);
                q.pop();

                if(front->left)
                q.push(front->left);

                if(front->right)
                q.push(front->right);
            }            
            vv.push_back(v);
            levelSize = q.size();
        }
        return vv;
    }
};

http://www.kler.cn/a/503477.html

相关文章:

  • Webpack和Vite的区别
  • 如何独立SDK模块到源码目录?
  • 【Linux】从零开始:编写你的第一个Linux进度条小程序
  • Nginx代理同域名前后端分离项目的完整步骤
  • primitive 的 Appearance编写着色器材质
  • 解决:ubuntu22.04中IsaacGymEnv保存视频报错的问题
  • 使用 versions-maven-plugin 和 flatten-maven-plugin 插件惯例 maven 项目版本
  • JUC Java并发编程 高级 学习大纲 动员
  • 保姆级图文详解:Linux和Docker常用终端命令
  • Mac玩Steam游戏秘籍!
  • Knife4j生成和展示API文档工具
  • Python自学 - “包”的创建与使用(从头晕到了然)
  • 电子邮件安全及核心概念
  • 探索AI与鸿蒙开发新领域:从《星火AI使用指南》到《鸿蒙应用开发宝典》
  • 远程连接不上怎么回事?
  • HTML5 滚动动画详解
  • 常见的php框架有哪几个?
  • 利用Java爬虫按图搜索1688商品(拍立淘)的实践指南
  • npm install 报错常见的解决方法
  • 论文阅读:SplatMAP: Online Dense Monocular SLAM with 3D Gaussian Splatting
  • 解决VMWare虚拟机“无法获取vmci驱动程序版本”的问题
  • 如何应对突然忘记 MySQL 登录密码的情况?
  • 宁德时代C++后端开发面试题及参考答案
  • 【DevOps】Jenkins配置钉钉邮件通知
  • Certificates do not conform to algorithm constraints
  • 【HarmonyOS之旅】基于ArkTS开发(二) -> UI开发二