描述
输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果。如果是则返回true,否则返回false。假设输入的数组的任意两个数字都互不相同。(ps:我们约定空树不是二叉搜素树)
算法
使用递归
时间复杂度O(logn)
空间复杂度O(1)
class Solution {
public:
bool VerifySquenceOfBST(vector<int> sequence) {
if (!sequence.size()) return false;
return IsBST(sequence, 0, sequence.size()-1);
}
bool IsBST(const vector<int>& sequence, const int start, const int end){
if (start>=end) return true; // 可能出现start>end的情况
int pivot;
for (pivot=start; sequence[pivot]<sequence[end]; ++pivot); // 查找分界点
for (int i=pivot; i<=end; ++i)
if (sequence[i]<sequence[end]) return false;
return IsBST(sequence, start, pivot-1) && IsBST(sequence, pivot, end-1);
}
};