现在的位置: 首页 > 综合 > 正文

判断整数序列是不是二元查找树的后续遍历结果

2014年02月20日 ⁄ 综合 ⁄ 共 358字 ⁄ 字号 评论关闭

boolean vertify(int[] sequence,int length)
{
if(sequence == null||length<0)
return false;
int root = sequence[length-1];
int i = 0;
for (; i < length-1; i++)
{
if(sequence[i]>root)
break;
}
int j = i;
for (; j < length-1; j++)
{
if(sequence[j]<root)
return false;

}

boolean left = true;
if(i>0)
left = vertify(sequence, i);
boolean right = true;
if(i<length-1)
right = vertify(sequence, length-i-1);

return left&&right;

}

抱歉!评论已关闭.