data:image/s3,"s3://crabby-images/fb1ae/fb1ae85a0f8a15750b2934c8ee032c265f7f4719" alt=""
data:image/s3,"s3://crabby-images/bdbed/bdbede960aaeb6ab9d49710cf6fd315d7c74ca9d" alt=""
3. Tree Specification
data:image/s3,"s3://crabby-images/24c63/24c63ab8cb2b4551aa9b042ee9f7be4af556628e" alt=""
Recall that we had 3 different styles of specification for
lists:
- the classical (list = collection of nodes),
- the recursive (list = EMPTY or 2 parts: head and tail (which is
a list))
- ours, which featured operations on whole lists rather
than on individual elements (SPLIT and JOIN).
Specifications for trees can be viewed as generalizations of list
specifications - a list is a degenerate kind of tree - so it is no
surprise that tree specifications also fall into these three
categories.
In fact, we have already seen the first two:
- a tree is a collection of nodes in which each node has exactly 1
predecessor (except the root, which has none) and any
number of successors (at most N, in the case of an N-ary tree).
- a binary tree is either empty or it has 3 parts: a value, a left
subtree, and a right subtree.
data:image/s3,"s3://crabby-images/fb1ae/fb1ae85a0f8a15750b2934c8ee032c265f7f4719" alt=""
data:image/s3,"s3://crabby-images/bdbed/bdbede960aaeb6ab9d49710cf6fd315d7c74ca9d" alt=""