美文网首页
剑指 Offer 31 栈的压入、弹出序列

剑指 Offer 31 栈的压入、弹出序列

作者: itbird01 | 来源:发表于2022-01-13 07:13 被阅读0次
题目.png

题意:输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如,序列 {1,2,3,4,5} 是某栈的压栈序列,序列 {4,5,3,2,1} 是该压栈序列对应的一个弹出序列,但 {4,3,5,1,2} 就不可能是该压栈序列的弹出序列。

解题思路

解法1:
1.分析题意,其实就是汉诺塔游戏,借助一个栈,实现另外两个数组的出栈和入栈操作,最终判定辅助栈是否为空即为结果
2.将push数组的元素不断入栈,每入栈一个,循环判断stack顶元素是否与pop一样,如果一样,就不断的出栈,直到push数组、pop数组全部遍历完成,辅助栈是否为空,即为结果

解题遇到的问题

后续需要总结学习的知识点

##解法1
import java.util.Stack;

class Solution {
    public static void main(String[] args) {
        System.out.println(validateStackSequences(new int[]{4, 3, 5, 1, 2},
                new int[]{4, 3, 5, 1, 2}));
    }
    public static boolean validateStackSequences(int[] pushed, int[] popped) {
        Stack<Integer> stack = new Stack<Integer>();
        int j = 0;
        for (int i = 0; i < pushed.length; i++) {
            stack.push(pushed[i]);
            while (!stack.isEmpty() && stack.peek() == popped[j]) {
                stack.pop();
                j++;
            }
        }
        return stack.isEmpty();
    }
}

相关文章

网友评论

      本文标题:剑指 Offer 31 栈的压入、弹出序列

      本文链接:https://www.haomeiwen.com/subject/hjhpqrtx.html