博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
数据结构之「树」
阅读量:5954 次
发布时间:2019-06-19

本文共 782 字,大约阅读时间需要 2 分钟。

什么是树?

是由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+树等,都是用来解决查询效率低的。

预告

后续会有二叉查找树、平衡二叉树、B树、B+树、图等内容,欢迎关注,让我们一起交流讨论计算机基础。

转载地址:http://xilxx.baihongyu.com/

你可能感兴趣的文章
我的友情链接
查看>>
账户注销完自动登录账户,并且不需要再点击屏幕的账户头像
查看>>
【Interface&navigation】按钮(29)
查看>>
我要学python之装饰器
查看>>
Extjs4.x (MVC)Controller中refs以及Ext.ComponentQuery解析
查看>>
消息最终一致性解决方案之RabbitMQ实现
查看>>
记录:网络通信协议中的TCP/IP与UDP
查看>>
我的友情链接
查看>>
基于YUM安装与源码编译或二进制多实例安装Mariadb,mysql
查看>>
基于jxl导入导出Excel
查看>>
多线程面试题
查看>>
GLKVector3参考
查看>>
学习:java设计模式—工厂模式
查看>>
CISCO路由器、交换机密码恢复
查看>>
Cgi与php-Cgi以及Fast-Cgi与php-fpm的理解
查看>>
我的友情链接
查看>>
odoo 财务会计相关介绍
查看>>
大型分布式C++框架《四:netio之请求包中转站 上》
查看>>
lnmp之PDO_mysql.so
查看>>
原码、补码、反码、1的补码
查看>>