(1). 二叉树的后序遍历方法(左→右→根)。
(2). 二叉查找树,又被称为二叉搜索树。其特点如下:设x为二叉查找树中的一个结点,x节点包含关键字key,一句话就是左孩子比父节点小,右孩子比父节点大,还有一个特性就是”中序遍历“可以让结点有序。看下图,解释一下:
可以看出,在二叉树中:
(1). 通过取出序列最后一个元素得到二叉搜索树的根节点;
(2). 在二叉搜索树中左子树的结点小于根结点,因此可以遍历一次得到左子树;
(3). 在二叉搜索树中右子树的结点大于根结点,因此可以继续遍历后序元素得到右子树;
(4). 重复以上步骤递归判断左右子树是不是二叉搜索树,如果都是,则输入yes,如果不是,则输出no;
class Solution
{
public bool VerifySquenceOfBST(int[] sequence)
{
// write code here
if(sequence.Length == 0)
{
return false;
}
return Verify(sequence, 0, sequence.Length-1);
}
public bool Verify(int[] sequence, int start, int end)
{
int root = sequence[end];
int i = start;
for(; i<end; i++)
{
if(sequence[i] > root)
break;
}
int j = i;
for(; j<end; j++)
{
if(sequence[j] < root)
return false;
}
bool left = true;
if(i-1 > start)
{
left = Verify(sequence, start, i-1);
}
bool right = true;
if(i < end-1)
{
right = Verify(sequence, i, end-1);
}
return (left && right);
}
}