栈(验证栈序列)(5)

一.题目

946. 验证栈序列 - 力扣(LeetCode)

二.思路讲解

2.1 思路讲解

验证栈序列的核心在于模拟 入栈和出栈的过程。我们使用一个辅助栈,按照 pushed 的顺序依次将元素压入栈中。

每次压入后,立即检查栈顶元素 是否等于 popped 序列当前指向的元素(用一个指针 j 指向 popped 的开头)。如果相等,则说明该元素需要立即弹出,于是执行出栈 操作,并将 j 指针后移一位,然后重复 检查新的栈顶是否与新的 popped[j] 相等,直到栈顶不再匹配或栈为空。

接着继续压入下一个 pushed 元素,重复上述过程。当所有 pushed 元素都处理完后,如果辅助栈为空,说明所有元素都能按照 popped 的顺序成功弹出,返回 true;否则返回 false

三.代码演示

cpp 复制代码
class Solution {
public:
    bool validateStackSequences(vector<int>& pushed, vector<int>& popped) 
    {
        int r = 0;//给出栈准备的
        stack<int>stack;
        for(const auto& x : pushed)
        {
            stack.push(x);
            while(!stack.empty() && stack.top() == popped[r])
            {
                stack.pop();
                r++;
            }
        } 
        return stack.empty();   
    }
};

四.代码演示

一、初始化栈和指针

首先,我们需要一个辅助栈 stack 来模拟入栈和出栈的过程。同时,定义一个整型变量 r 作为指针,指向 popped 序列中当前待弹出的元素位置,初始值为 0

二、遍历入栈序列

使用范围 for 循环遍历 pushed 数组中的每一个元素 x。对于每个元素,执行以下操作:

  • 将当前元素 x 压入栈中,即 stack.push(x)。这一步模拟了入栈操作。
三、尝试弹出匹配的元素

在每次压入新元素后,立即检查栈顶元素是否与 popped 序列中当前指针 r 所指向的元素相等。我们使用一个 while 循环 ,条件为 !stack.empty() && stack.top() == popped[r],即栈非空且栈顶元素正好是待弹出的元素时,执行弹出操作:

  • 弹出栈顶元素:stack.pop()

  • 将指针 r 向后移动一位:r++,表示下一个待弹出的元素位置。

这个 while 循环会一直进行,直到栈顶不再匹配或栈为空为止。这样可以一次性处理连续弹出的情况,例如在示例1中,压入4后栈顶为4,正好匹配,弹出后栈顶变为3,继续匹配,直到不匹配为止。

四、最终判断

当遍历完所有 pushed 元素后,如果整个入栈出栈序列是合法的,那么栈应该为空,即所有元素都按顺序成功弹出。因此,返回 stack.empty() 即可:如果栈为空,返回 true;否则返回 false

相关推荐
三毛的二哥2 小时前
障碍物遮挡判断算法
人工智能·算法·计算机视觉·3d
啊我不会诶2 小时前
2025ICPC南昌邀请赛vp补题
算法
发发就是发2 小时前
I2C适配器与算法:从一次诡异的时序问题说起
服务器·驱动开发·单片机·嵌入式硬件·算法·fpga开发
啊哦呃咦唔鱼2 小时前
leetcode二分查找
数据结构·算法·leetcode
(Charon)2 小时前
【Qt/C++】Qt/C++ 中 :: 和 . 到底有什么区别?
开发语言·c++·qt
REDcker2 小时前
C++跨平台与跨语言绑定工具:SWIG、Djinni 等选型
开发语言·c++
郝学胜-神的一滴2 小时前
[ 力扣 1124 ] 解锁最长良好时段问题:前缀和+哈希表的优雅解法
java·开发语言·数据结构·python·算法·leetcode·散列表
戴西软件2 小时前
戴西CAxWorks.VPG车辆工程仿真软件|假人+座椅双调整 汽车仿真效率直接拉满
java·开发语言·人工智能·python·算法·ui·汽车
北漂Zachary2 小时前
PHP vs C++ vs 易语言:三大语言对比解析
开发语言·c++·php