数据结构之「树」

什么是树?

树是由n(n>0)个有限节点组成一个具有层次关系的集合,一个父节点有0个或多个子节点。
用树结构来表示一对多的关系。
树的特点:
1.没有父节点的节点称为根节点。
2.每一个非根节点有且只有一个父节点。
3.除了根节点外,每个子节点可以分为多个不相交的子树。
4.每个节点都 0 个或多个子节点。
5.树里没有环路,就是节点只能向下衍生,跟树一样,不能相交于其它子树。


树的术语

根节点:没有父几点,并且每棵树只有一个根节点。
父节点:若一个节点含有子节点,则这个节点称为其子节点的父节点。
子节点:一个节点含有的子树的根节点称为该节点的子节点。
叶子节点:最底层的,度为零的节点。
兄弟节点:具有相同父节点的节点互称为兄弟节点。
堂兄弟节点:父节点在同一层的节点互为堂兄弟。
分支节点:中间的,度不为零的节点。
节点的度:一个节点含有的子树的个数称为该节点的度。
树的度:一棵树中,最大的节点的度称为树的度。
深度:对于任意节点 n, n 的深度为从根到 n 的唯一路径长,根的深度为 0。
高度:对于任意节点 n, n 的高度为从 n 到一片树叶的最长路径,所有叶子节点的高度为 0。
节点的祖先:从根到该节点所经分支上的所有节点。
节点的子孙:以某节点为根的子树中任一节点都称为该节点的子孙。
节点的层次:从根开始定义起,根为第 1 层,根的子节点为第 2 层,以此类推。
森林:由m(m >= 0)棵互不相交的树的集合称为森林。

总结

树 实际上就是表示一对多的关系,数组和链表遍历查找时间复杂度是 O(n),当 n 很大时,就非常影响查询效率,因此需要其他的数据结构来解决此类问题。就像二叉查找树、平衡二叉树、B树、B+树等,都是用来解决查询效率低的。

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 一些概念 数据结构就是研究数据的逻辑结构和物理结构以及它们之间相互关系,并对这种结构定义相应的运算,而且确保经过这...
    Winterfell_Z阅读 6,612评论 0 13
  • 前言 总括: 本文讲解了数据结构中的[树]的概念,尽可能通俗易懂的解释树这种数据结构的概念,使用javascrip...
    秦至阅读 888评论 0 6
  • 树形结构是一种非常重要的非线性的数据结构。树结构与线性结构不同之处:线性结构中任意一个元素最多只有一个后继元素,而...
    zgwyvd阅读 2,623评论 0 7
  • 美联摄阅读 234评论 0 0
  • 纠结了很久,到底要不要把它记录下来,毕竟是那么揪心的事情,记录它,写下它,无疑是再重新复读一遍事情的经过,很残忍很...
    Fwx烟雨倾城阅读 328评论 0 2

友情链接更多精彩内容