您的位置:首页 > 其它

判断二叉树的后续遍历序列

2016-05-27 23:16 387 查看
判断二叉树的后续遍历序列

bool VerifySquenceOfBST(vector<int> sequence) {
if(sequence.empty())
return false;
int len =sequence.size();
int i=0;
int root=sequence[len-1];
vector<int> left;
vector<int> right;
for(;i<len-1&&sequence[i]<root;i++)left.push_back(sequence[i]); //i<len-1 因为[len-1]是root
for(;i<len-1&&sequence[i]>root;i++)right.push_back(sequence[i]);
if(i==len-1)
return (left.size()?VerifySquenceOfBST(left):1) //要判断子树是否为空
&&(right.size()?VerifySquenceOfBST(right):1);
else
return false;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  遍历