Leetcode——栈的压入弹出序列

Posted Yawn,

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Leetcode——栈的压入弹出序列相关的知识,希望对你有一定的参考价值。

1. 栈的压入、弹出序列

(1)模拟

给定一个压入序列 pushedpushed 和弹出序列 poppedpopped ,则压入 / 弹出操作的顺序(即排列)是 唯一确定 的。

如下图所示,栈的数据操作具有 先入后出 的特性,因此某些弹出序列是无法实现的。

考虑借用一个辅助栈 stack,模拟 压入 / 弹出操作的排列。根据是否模拟成功,即可得到结果。

  • 入栈操作: 按照压栈序列的顺序执行。
  • 出栈操作: 每次入栈后,循环判断 “栈顶元素 == 弹出序列的当前元素” 是否成立,将符合弹出序列顺序的栈顶元素全部弹出。

ps:题目规定 栈的所有数字均不相等,因此在循环入栈中,每个元素出栈的位置的可能性是唯一的(若有重复数字,则具有多个可出栈的位置).
因而,在遇到 “栈顶元素 == 弹出序列的当前元素” 就应立即执行出栈。

算法流程:


时空复杂度:O(n)

class Solution {
    public boolean validateStackSequences(int[] pushed, int[] popped) {
        Deque<Integer> stack = new LinkedList<>();
        int i = 0;

        for (int num : pushed) {
            //num入栈
            stack.push(num);

            // 循环判断与出栈序列是否相等
            while (!stack.isEmpty() && stack.peek() == popped[i]) {
                stack.pop();
                i++;
            }
        }
        return stack.isEmpty();
    }
}

以上是关于Leetcode——栈的压入弹出序列的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode 面试题31. 栈的压入弹出序列

leetcode-栈的压入弹出序列-62

LeetCode-栈栈的压入弹出序列

[LeetCode]剑指 Offer 31. 栈的压入弹出序列

[LeetCode]剑指 Offer 31. 栈的压入弹出序列

LeetCode(剑指 Offer)- 31. 栈的压入弹出序列