经典问题——验证栈序列

我们先来看题目描述:

给定 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;
    }
};
相关推荐
2501_906565121 小时前
勾股定理证明
算法
Shan12052 小时前
无向图的Hierholzer算法流程(二)
算法
gihigo19982 小时前
基于蒙特卡洛的异常值剔除(RANSAC + MC置信区间)—MATLAB实现
开发语言·算法·matlab
Asize2 小时前
数组数据结构底层:从灵活到陷阱
前端·javascript·算法
hairenwangmiao3 小时前
B4041 [GESP202409 四级] 区间排序
算法·排序
人道领域3 小时前
【LeetCode刷题日记】47.全排列Ⅱ
java·开发语言·算法·leetcode
漂流瓶jz3 小时前
UVA-1606 两亲性分子 题解答案代码 算法竞赛入门经典第二版
数据结构·算法·向量·aoapc·算法竞赛入门经典·atan2·浮点
Navigator_Z3 小时前
LeetCode //C - 1095. Find in Mountain Array
c语言·算法·leetcode
不会就选b4 小时前
算法日常・每日刷题--<二分查找>1
算法