
题意:输入两个整数序列,第一个序列表示栈的压入顺序,请判断第二个序列是否为该栈的弹出顺序。假设压入栈的所有数字均不相等。例如,序列 {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();
}
}
网友评论