 Data Structures and Algorithms 
with Object-Oriented Design Patterns in C++
Data Structures and Algorithms 
with Object-Oriented Design Patterns in C++ 
  
  
  
  
 
Consider a tree   ,
,   ,
as given by Definition
,
as given by Definition  .
.
 of subtree
 of subtree   of tree T is called a child  of r.
	The term grandchild is defined in a similar manner.
	of tree T is called a child  of r.
	The term grandchild is defined in a similar manner. of the subtrees
 of the subtrees   ,
,   .
	The term grandparent is defined in a similar manner.
.
	The term grandparent is defined in a similar manner. and
 and   of distinct subtrees
 of distinct subtrees   and
	and   of tree T are called siblings .
 of tree T are called siblings .
Clearly the terminology used for describing tree data structures is a curious mixture of the mathematical, the genealogical, and the botanical. There is still more terminology to be introduced, but in order to do that, we need the following definition:
Definition (Path and Path Length) Given a tree T containing the set of nodes R, a path in T is defined as a non-empty sequence of nodes
where
, for
such that the
node in the sequence,
, is the parent of the
node in the sequence
. The length of path P is k-1.
For example, consider again the tree   shown in Figure
 shown in Figure  .
This tree contains many different paths.
In fact, if you count carefully, you should find that there are exactly 29
distinct paths in tree
.
This tree contains many different paths.
In fact, if you count carefully, you should find that there are exactly 29
distinct paths in tree   .
This includes the path of length zero,
.
This includes the path of length zero,   ;
the path of length one,
;
the path of length one,   ;
and the path of length three,
;
and the path of length three,   .
.
 
  
  
  
  
 
 Copyright © 1997 by Bruno R. Preiss, P.Eng.  All rights reserved.
Copyright © 1997 by Bruno R. Preiss, P.Eng.  All rights reserved.