输⼊⼀个整数数组,判断该数组是不是某⼆叉搜索树的后序遍历的结果。如果是则返回true,否则返回false 。假设输⼊的数组的任意两个数字都互不相同。
提示:
示例1
输⼊:[1,3,2]
返回值:true
说明:是上图的后序遍历 ,返回true
需要判断给定的整数数组是否是某个二叉搜索树(BST)的后序遍历结果。二叉搜索树具有以下特性:
后序遍历的顺序是:左子树 → 右子树 → 根节点,因此数组的最后一个元素一定是根节点
注意是⼆叉搜索树,如果是后续遍历的话,那么应该最后⼀个元素是中间元素 mid ,前⾯的元素可以分为两部分,⼀部分⽐ mid ⼩,另⼀部分全部⽐ mid ⼤。如果破坏这个原则,那么就应该输出No 。采取分⽽治之的⽅法,分别递归检查左⼦树以及右⼦树:
public class Solution {
public boolean VerifySquenceOfBST(int[] postorder) {
if (postorder == null || postorder.length == 0) {
return false; // 空树不是BST
}
return verify(postorder, 0, postorder.length - 1);
}
private boolean verify(int[] postorder, int start, int end) {
if (start >= end) {
return true; // 单个节点总是BST
}
int root = postorder[end]; // 根节点是最后一个元素
int i = start;
// 找到第一个大于根节点的元素,作为左右子树分界
while (i
利用单调栈和后序遍历的倒序特性:
public boolean verifyPostorder(int[] postorder) {
if (postorder == null || postorder.length == 0) {
return false;
}
Stack stack = new Stack();
int max = Integer.MAX_VALUE; // 初始化最大值
// 从后往前遍历
for (int i = postorder.length - 1; i >= 0; i--) {
int current = postorder[i];
// 如果当前节点大于max,违反BST性质
if (current > max) {
return false;
}
// 弹出所有比当前节点大的元素,并更新max
while (!stack.isEmpty() && stack.peek() > current) {
max = stack.pop();
}
stack.push(current);
}
return true;
}
本文来自在线网站:seven的菜鸟成长之路,作者:seven,转载请注明原文链接:www.seven97.top
参与评论
手机查看
返回顶部