假定用两个一维数组L[1..n]和R[1..n]作为有n个结点的二叉树的存储结构, L[i]和R[i]分别指示结点i的左孩子和右孩子,0表示空。试写一个算法判别结点u是否为结点v的子孙。
一维数组类型Array1D的定义:
typedef int Array1D[MAXSIZE];
实现函数如下:
Status Dencendant(Array1D L,Array1D R,int n,int u,int v)
/* If node 'u' is the dencendant of node 'v', */
/* then return 'TRUE' else return 'FALSE'. */
/* L[i] is the left child of the i_th node, */
/* R[i] is the right child of the i_th node */
/* in the Binary Tree which has n nodes. */
{
int flag = 0;
if(!v)return FALSE;
else{
if(L[v] == u || R[v] == u)
//判断u是否为v的子节点
return TRUE;
else if(Dencendant(L,R,n,u,L[v]) || Dencendant(L,R,n,u,R[v]))
//递归判断u是否为v的子孙节点
return TRUE;
else
return FALSE;
}
}