1、树的定义及存储结构:树是一种非线性的数据结构,它是由n(n>=1)个有限节点组成的一种具有层次关系的集合,之所以称之为树,是因为它长得像一颗倒过来的树。
2、树的相关概念及术语
节点<node>:树中每个元素都叫做节点。
根节点或树根<root>:树顶端的节点。
子树<subTree>:除根节点之外,其他节点可以分为多个树的集合,叫做子树。
节点的度:一个节点直接含有子树的个数。
叶子结点、叶节点、终端节点:度为0的节点叫叶子节点。
双亲节点,父节点:父节点就是一个节点上头的那个节点,如果一个节点包含若干字节点,那么这个节点就是这些子节点的父节点,也叫双亲节点。
兄弟节点:拥有相同父节点的节点叫做兄弟节点。
树的度:一个树中最大节点的度叫做树的度。
节点的层次: 从根节点开始一直到最下面一层,根算第1层,根的子节点算第2层。
树的高度、深度:树的高度是从根节点开始,由顶向下逐层累加。深度从上到下。
树的高度是从叶节点开始,自底向上逐层累加,高度由下向上。
虽然树的深度和高度看似一样,但具体到某个节点上,高度和深度还是不一样的。
3、树的种类:
树的种类有很多,我们接触到的树有二叉树、平衡二叉树、二叉查找树、B树、B+树、哈夫曼树、B*树、红黑树和trie树等。</