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

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

关于我:



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

PDF版免费提供:倘若有需要,想拿我写的博客进行学习和交流,可以私信我将免费提供PDF版。

留下你的建议:倘若你发现本文中的内容和配图有任何错误或改进建议,请直接评论或者私信。

倡导提问与交流:关于本文任何不明之处,请及时评论和私信,看到即回复。


1.前言

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

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

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

2.题目简介

题目链接:LINK

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

3.题解思路

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

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

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

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

4.参考代码

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();
    }
};


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

相关文章
|
18天前
|
存储 算法 搜索推荐
探索常见数据结构:数组、链表、栈、队列、树和图
探索常见数据结构:数组、链表、栈、队列、树和图
84 64
|
11天前
|
算法 程序员 索引
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器
栈的基本概念、应用场景以及如何使用数组和单链表模拟栈,并展示了如何利用栈和中缀表达式实现一个综合计算器。
16 1
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器
|
11天前
初步认识栈和队列
初步认识栈和队列
35 10
|
5天前
数据结构(栈与列队)
数据结构(栈与列队)
11 1
|
27天前
|
算法 安全 测试技术
golang 栈数据结构的实现和应用
本文详细介绍了“栈”这一数据结构的特点,并用Golang实现栈。栈是一种FILO(First In Last Out,即先进后出或后进先出)的数据结构。文章展示了如何用slice和链表来实现栈,并通过golang benchmark测试了二者的性能差异。此外,还提供了几个使用栈结构解决的实际算法问题示例,如有效的括号匹配等。
golang 栈数据结构的实现和应用
|
11天前
|
算法
数据结构与算法二:栈、前缀、中缀、后缀表达式、中缀表达式转换为后缀表达式
这篇文章讲解了栈的基本概念及其应用,并详细介绍了中缀表达式转换为后缀表达式的算法和实现步骤。
28 3
|
9天前
|
存储 JavaScript 前端开发
为什么基础数据类型存放在栈中,而引用数据类型存放在堆中?
为什么基础数据类型存放在栈中,而引用数据类型存放在堆中?
37 1
|
12天前
|
存储 安全 Java
【用Java学习数据结构系列】探索栈和队列的无尽秘密
【用Java学习数据结构系列】探索栈和队列的无尽秘密
25 2
|
18天前
|
Go
数据结构之 - 深入了解栈数据结构
数据结构之 - 深入了解栈数据结构
18 5
【数据结构】--- 栈和队列
【数据结构】--- 栈和队列