数据结构之树(图解)

文章目录

  • 前言
  • 一、树是什么?
  • 二、树的特点
  • 三、树的相关概念
  • 四、树的表示方法(孩子兄弟表示法)
  • 总结


前言

在学习完线性结构,例如顺序表、链表、栈、队列后,我们要开始学习一个新的数据结构----树

一、树是什么?

首先树是一个非线性的数据结构,由有限个节点组成的一个具有层次的集合。
如图,下面是树的逻辑结构,因为逻辑结构像一颗倒挂的树,也就是根在上,树枝朝下。
顾名思义被称为“”。

树的逻辑结构

二、树的特点

	我们来看上面的图
  1. 根节点:没有前驱结点的节点,如图中的A。
  2. 除根节点外,其余结点被分成M(M>0)个互不相交的集合T1、T2、……、Tm,其中每一个集合Ti
    (1<= i <= m)又是一棵结构与树类似的子树。每棵子树的根结点有且只有一个前驱,可以有0个或多个后继
  3. 树是递归定义的。
  4. 树又被称作树形结构,是一对多的,也就是一个节点对应多个节点。

三、树的相关概念

  1. N个节点的树有N-1条边
  2. 节点的度: 一个节点含有的子树的个数称为该节点的度 ;如图:A的度为3
  3. 树的度: 一棵树中,最大的节点的度称为树的度;如上图:树的度为3
  4. 叶节点或终端节点: 度为0的节点称为叶节点; 如上图:J、K、L、M、G等节点
  5. 叶节点分枝节点: 度不为0的节点,有孩子节点的节点
  6. 父节点: 有子树的节点,有子节点的节点子节点:有父节点的节点
  7. 兄弟节点: 具有相同父节点的节点
  8. 堂兄弟节点: 双亲在同一层的节点
  9. 节点的层次: 根节点是第一层,以此类推
  10. 树的高度或深度: 树中节点的最大层次,也是叶节点的层次
  11. 节点的祖先: 从根节点到该节点的所有节点都是这个节点的祖先,也就是从根节点往下找这个节点经过 的节点,当然也包括根节点。
  12. 子孙: 以某个节点为根节点的子树中的任意一个节点都是该节点的子孙
  13. 森林: 互不相交的多棵树叫森林

树

四、树的表示方法(孩子兄弟表示法)

我们想用代码来写出一个完整的树,需要考虑的因素太多了,方法也很多,在这里我们讲一个树的最优方法供大家学习。

我们知道树是一对多的结构,所以这也同样会用到指针,但是指针应该有几个,都指向谁?这就又是一个问题了。不要慌张,先来看这颗树的逻辑结构。
树的逻辑结构

我们看到首先A这个根节点 链接着分别以B、C、D三个为根节点的子树,那我们是否就要在A这个节点上加三个指针呢?那是不是如果A链接4个就要加四个指针?很明显不可能这么做,这个时候就有一位大神发明了一种方法(孩子兄弟表示法)
这个方法总结成一句话就是,“父母看老大,老大看老二,老二看老三”。

如图:

孩子兄弟表示法

总结

以上就是我们今天讲述的 树的结构,下节课让我们继续学习新的知识-----二叉树

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/159555.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数模国赛——多波束测线问题模型建立研究分析

第一次参加数模国赛&#xff0c;太菜了~~~~意难平 问题一 画出与测线方向垂直的平面和海底坡面的交线构成一条与水平面夹角为&#x1d400;的斜线的情况下的示意图进行分析&#xff0c;将覆盖宽度分为左覆盖宽度和右覆盖宽度&#xff0c;求出它们与海水深度和&#x1d400;、…

RT-Thread系统使用常见问题处理记录

1.使用telnet连接系统时发送help指令显示不全的问题。 原因&#xff1a;telnet发送缓存太小。 解决办法&#xff1a;更改agile_telnet软件包里Set agile_telnet tx buffer size的大小。 2.使用Paho MQTT软件包过一段时间报错hard fault on thread: mqtt0 解决办法&#xff1…

Mysql高级——Mysql8一主一从,多主多从搭建

修改 /etc/hosts文件 ip地址 master1 ip地址 master2 ip地址 slave1 ip地址 slave2一主一从 create database master1db;create table master1db.master1tab(name char(50));insert into master1db.master1tab VALUES(1111);insert into master1db.master1tab VALUES(2222);m…

【Java】多线程案例(单例模式,阻塞队列,定时器,线程池)

❤️ Author&#xff1a; 老九 ☕️ 个人博客&#xff1a;老九的CSDN博客 &#x1f64f; 个人名言&#xff1a;不可控之事 乐观面对 &#x1f60d; 系列专栏&#xff1a; 文章目录 实现安全版本的单例模式饿汉模式类和对象的概念类对象类的静态成员与实例成员 懒汉模式如何保证…

无需专线、无需固定公网IP,各地安防数据如何高效上云?

某专注于安防领域的企业&#xff0c;供机场、金融、智慧大厦等行业&#xff0c;包括门禁系统、巡更系统、视频监控在内的整体解决方案。 在实际方案交付过程中&#xff0c;往往需要在多地分支机构分别部署相应的安防设备&#xff0c;并将产生的数据实时统一汇总至云平台进行管理…

springboot+vue基于JAVA的企业内部人员绩效量化管理系统的设计与实现【内含源码+文档+部署教程】

博主介绍&#xff1a;✌全网粉丝10W,前互联网大厂软件研发、集结硕博英豪成立工作室。专注于计算机相关专业毕业设计项目实战6年之久&#xff0c;选择我们就是选择放心、选择安心毕业✌ &#x1f345;由于篇幅限制&#xff0c;想要获取完整文章或者源码&#xff0c;或者代做&am…

centos9 stream 下 rabbitmq高可用集群搭建及使用

RabbitMQ是一种常用的消息队列系统&#xff0c;可以快速搭建一个高可用的集群环境&#xff0c;以提高系统的弹性和可靠性。下面是搭建RabbitMQ集群的步骤&#xff1a; 基于centos9 stream系统 1. 安装Erlang和RabbitMQ 首先需要在所有节点上安装Erlang和RabbitMQ。建议使用官…

【带头学C++】----- 三、指针章* ---- 3.1指针变量的定义

指针在C语言是核心&#xff0c;在C中更是核心。所以本章节将详细讲解指针的使用方法以及指针的一些特殊用法&#xff0c;和引用的区别&#xff0c;以及指针涉及到一些算法基础。通过案例引导&#xff0c;使得能更清楚命明白。在C中的指针是一种数据类型&#xff0c;其使用方法和…

布雷斯悖论和借贷式拥塞控制

先看布雷斯悖论&#xff0c;新增一条路不但没减少交通延滞&#xff0c;反而降低了服务水准&#xff0c;下面一个简单的例子&#xff1a; 关于布雷斯悖论的讨论已经太多&#xff0c;我给出个新解释&#xff0c;这和我引出 借贷式拥塞控制 (差论证和编码)有关。 看一个不严谨但更…

K-edge 和逃逸问题

一 k-eage基本概念 1 k-edge概念 K-edge称为K边, 其物理意义是高原子序数物质原子内部K层自由电子, 易与特定能量下X射线光子发生光电吸收作用, 导致对该能量的X射线光子吸收特别大。 而K-edge特性表现为X射线与物质发生相互作用时, 其衰减系数随着能量的增加而逐渐减小, 但在…

Python武器库开发-常用模块之configparser模块(十六)

configparser模块(十六) ConfigParser模块在python3中修改为configparser.这个模块定义了一个ConfigParser类&#xff0c;该模块的作用就是用来读取配置文件的&#xff0c;使用模块中的RawConfigParser()、ConfigParser()、 SafeConfigParser()这三个方法&#xff0c;创建一个…

路由器基础(十二):IPSEC VPN配置

一、IPSec VPN基本知识 完整的IPSec协议由加密、摘要、对称密钥交换、安全协议四个部分组成。 两台路由器要建立IPSecVPN连接&#xff0c;就需要保证各自采用加密、摘要、对称密钥 交换、安全协议的参数一致。但是IPSec协议并没有确保这些参数一致的手段。 同时&#xff0c;IP…