1.1、树的定义
之前提到的数组、单链表、栈、队列这些都是一对一的线性结构,可现实中却有很多一对多的情况需要处理,所以我们需要研究这种一对多的树形结构。树形结构可是比线性结构要复杂、繁琐得多,并且树形结构有非常多的子类结构:二叉树、堆、红黑树、B树、B+树等等。每个子类树在查找、排序、编码压缩、文件管理等等各个方面都展现了优秀的性能优势,这也是为什么要学习树形结构的重要原因。
树( Tree')是 n(n≥0) 个结点的有限集。n=0时无节点,称为空树。
在任意1棵非空树中:
- 有且仅有1个特定的称为根 (Root )的结点。
- n>1 时,其余结点可分为m (m>0) 个互不相变的有限集,其中每一个集合本身又是一槐树,并且称为根的子树( SubTree )。
- n>0 时,树的根结点是唯一的,不可能存在多个根结点,数据结向中的树是只能有一个根结点。
- m>0 时,子树的个数没有限制,但它们一定是不相交的(结点不重复),如下图。