经典问题——验证栈序列

我们先来看题目描述:

给定 pushed 和 popped 两个序列,每个序列中的值都不重复,只有当它们可能是在最初空栈上进行的推入 push 和弹出 pop 操作序列的结果时,返回 true ;否则,返回 false 。

示例 1:

**输入:**pushed = 1,2,3,4,5 , popped = 4,5,3,2,1

**输出:**true

**解释:**我们可以按以下顺序执行:push(1) , push(2) , push(3) , push(4) , pop() -> 4 , push(5) , pop() -> 5 , pop() -> 3, pop() -> 2 , pop() -> 1 。

示例 2:

输入:

pushed = 1,2,3,4,5 , popped = 4,3,5,1,2

输出:

false

解释:

1 不能在 2 之前弹出。

提示:

1 <= pushed.length <= 1000 0 <= pushedi <= 1000 pushed 的所有元素互不相同 popped.length == pushed.length popped 是 pushed 的一个排列。

解析:

只要模拟入栈和出栈的过程,将一个数进行入栈操作的时候检查该数是否为下一个要出栈的数,如果是就弹出该数,并继续检查栈中的数。如果能扫描完所有要出栈的数,就是一个合法的栈序列。

Java 代码实现:(使用 ArrayList 模拟栈)

复制代码
class Solution {
    public boolean validateStackSequences(int[] pushed, int[] popped) {
        List<Integer> S=new ArrayList<>();
        int j=0;
        for(int i=0;i<pushed.length;i++){
            S.add(pushed[i]);
            while(S.size()>0&&j<popped.length&&S.get(S.size()-1)==popped[j]){
                S.remove(S.size()-1);
                j++;
            }
        }
        return j==popped.length;
    }
}

C++ 代码实现:(直接用 STL stack )

复制代码
class Solution {
public:
    bool validateStackSequences(vector<int>& pushed, vector<int>& popped) {
        stack<int>S;
        int n=pushed.size();
        int j=0;
        for(int i=0;i<n;i++){
            S.push(pushed[i]);
            while(S.size()>0&&j<n&&S.top()==popped[j]){
                S.pop();
                j++;
            }
        }
        return j==n;
    }
};
相关推荐
古城小栈7 小时前
为啥说:训练用BF16,推理用FP16
人工智能·算法·机器学习
KaMeidebaby7 小时前
卡梅德生物技术快报|蛋白 N 端测序在重组贻贝融合蛋白表征中的应用,解决原核表达序列偏移工艺难题
前端·人工智能·物联网·算法·百度
Turbo正则8 小时前
群论在AI中的应用概述
人工智能·算法·抽象代数
ysa0510308 小时前
【并查集】判环
c++·笔记·算法
Jerry8 小时前
KeetCode 44. 开发商购买土地
算法
Jerry9 小时前
KeetCode 58. 区间和
算法
Jerry9 小时前
LeetCode 209. 长度最小的子数组
算法
彦为君10 小时前
算法思维与经典智力题
java·前端·redis·算法
智能优化与强化学习10 小时前
Gym(Gymnasium)仿真环境详解(二):环境简介、入门算法、调参要点、核心挑战
算法·强化学习·gym·零基础入门·算法评估
mxwin10 小时前
Unity Shader exp 函数的算法与渲染应用
算法·unity·游戏引擎·shader