class Solution {
public boolean verifyPostorder(int[] postorder) {
return verifySquenceofBST(postorder,0,postorder.length-1);
}
boolean verifySquenceofBST(int[] sequence ,int start,int end){
//如果left==right,就一个节点不需要判断了,如果left>right说明没有节点,
//也不用再看了,否则就要继续往下判断
if(start >= end) return true;
//因为数组中最后一个值postorder[right]是根节点,这里从左往右找出第一个比
//根节点大的值,他后面的都是根节点的右子节点(包含当前值,不包含最后一个值,
//因为最后一个是根节点),他前面的都是根节点的左子节点
int root = sequence[end];
int mid = start;
while(sequence[mid] < root){
mid++;
}
int tmp = mid;
//因为postorder[mid]前面的值都是比根节点root小的,
//我们还需要确定postorder[mid]后面的值都要比根节点root大,
//如果后面有比根节点小的直接返回false
while(tmp < end){
if(sequence[tmp++] < root){
return false;
}
}
//然后对左右子节点进行递归调用
return verifySquenceofBST(sequence,start,mid-1) && verifySquenceofBST(sequence,mid,end-1);
}
}