【practise】栈的压入和弹出序列

关于我:

睡觉待开机:个人主页

个人专栏: 《优选算法》《C语言》《CPP》 生活的理想,就是为了理想的生活! 作者留言

PDF版免费提供 :倘若有需要,想拿我写的博客进行学习和交流,可以私信我将免费提供PDF版。
留下你的建议 :倘若你发现本文中的内容和配图有任何错误或改进建议,请直接评论或者私信。
倡导提问与交流 :关于本文任何不明之处,请及时评论和私信,看到即回复。


参考目录


1.前言

我们知道对于同一入栈的队列,在出栈时候也会因为出栈的时机不同从而造成不同的出栈顺序,那该如何判断一串出栈队列属于该入栈队列的某一出栈顺序呢???

下面我们来介绍题目------栈的压入和弹出序列。

所以说,对于同一入栈序列,不同的出栈时间也会影响出栈结果。

2.题目简介

题目链接:LINK

题意很简单,给我们一组入栈和出栈序列,检验是否匹配。

3.题解思路

思路很简单,我们模拟入栈出栈次序,看是否匹配。

  • 先把入栈序列入栈
  • 栈顶元素和出栈序列是否匹配
    • 匹配,持续出数据,直到不匹配或者栈为空
    • 不匹配,继续第一步...

当入栈序列走完了,我们就可以判断结果了。

  • 如果栈不为空,则不匹配。
  • 如果栈为空,则匹配。

4.参考代码

cpp 复制代码
class Solution {
public:
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param pushV int整型vector 
     * @param popV int整型vector 
     * @return bool布尔型
     */
    bool IsPopOrder(vector<int>& pushV, vector<int>& popV) 
    {
        // write code here
        int pushi = 0;
        int popi = 0;
        stack<int> st;
        while(pushi != pushV.size())
        {
            //数据入栈
            st.push(pushV[pushi]);
            //判断是否匹配,出栈(栈必须非空才可以top)
            while(!st.empty() && st.top() == popV[popi])
            {
                //匹配,我们就出栈,popi++
                st.pop();
                popi++;
            }
            
            pushi++;
        }
        
        //如果st为空,则证明匹配,如果不为空,则证明不匹配。
        return st.empty();
    }
};

好的,如果本篇文章对你有帮助,不妨点个赞~谢谢。

相关推荐
LawrenceLan2 小时前
Flutter 零基础入门(十一):空安全(Null Safety)基础
开发语言·flutter·dart
txinyu的博客3 小时前
解析业务层的key冲突问题
开发语言·c++·分布式
码不停蹄Zzz3 小时前
C语言第1章
c语言·开发语言
行者963 小时前
Flutter跨平台开发在OpenHarmony上的评分组件实现与优化
开发语言·flutter·harmonyos·鸿蒙
阿蒙Amon4 小时前
C#每日面试题-Array和ArrayList的区别
java·开发语言·c#
SmartRadio4 小时前
ESP32添加修改蓝牙名称和获取蓝牙连接状态的AT命令-完整UART BLE服务功能后的完整`main.c`代码
c语言·开发语言·c++·esp32·ble
且去填词4 小时前
Go 语言的“反叛”——为什么少即是多?
开发语言·后端·面试·go
知乎的哥廷根数学学派4 小时前
基于生成对抗U-Net混合架构的隧道衬砌缺陷地质雷达数据智能反演与成像方法(以模拟信号为例,Pytorch)
开发语言·人工智能·pytorch·python·深度学习·机器学习
yeziyfx5 小时前
kotlin中 ?:的用法
android·开发语言·kotlin
charlie1145141915 小时前
嵌入式的现代C++教程——constexpr与设计技巧
开发语言·c++·笔记·单片机·学习·算法·嵌入式