C++数据结构X篇_12_树的基本概念和存储

学习二叉树之前先学习树的概念。

文章目录

  • 1. 树的基本概念
    • 1.1 树的定义
    • 1.2 树的特点
    • 1.3 若干术语
  • 2. 树的表示法
    • 2.1 图形表示法
    • 2.2 广义表表示法
  • 3. 树的存储
    • 3.1 双亲表示法:保存父节点关系
    • 3.2 孩子表示法
    • 3.3 左孩子右兄弟表示法

1. 树的基本概念

之前所学均为线性表,线性表具有什么特点呢?
第一个节点只有一个后继结点,没有前驱,最后一个节点,只有一个前驱,没有后继,其他位置的节点都有前驱和后继。
线性表中每个节点之间都是一对一的关系,存储也就相对容易一些。

下图就是一个树的结构,每一个节点是一对多的关系,每一个节点都有一个双亲节点(父节点、爹妈节点),但是有多个后继,这就是树概念
在这里插入图片描述

1.1 树的定义

由一个或多个(n≥0)结点组成的有限集合 T,有且仅有一个结点称为根(root),当n>1时,其余的结点分为m(m≥0)个互不相交的有限集合 T1,T2,…,Tm。每个集合本身又是棵树,被称作这个根的子树。

1.2 树的特点

  • 非线性结构,有一个直接前驱,但可能有多个直接后继(1:n )
  • 树的定义具有递归性,树中还有树。
  • 树可以为空,即节点个数为 0。

1.3 若干术语

  • –>即根结点(没有前驱)
  • 叶子–>即终端结点(没有后继)
  • 森林–>指 m 棵不相交的树的集合(例如删除 A 后的子树个数)
  • 有序数–>结点各子树从左至右有序,不能互换(左为第一)
  • 无序树–>结点各子树可互换位置。
  • 双亲–>即上层的那个结点(直接前驱) parent
  • 孩子–>即下层结点的子树(直接后继) child
  • 兄弟–>同一双亲下的同层结点(孩子之间互称兄弟) sibling
  • 堂兄弟–>即双亲位于同一层的结点(但并非同一双亲)cousin
  • 祖先–>即从根到该结点所经分支的所有结点
  • 子孙–>即该结点下层子树中的任一结点
    在这里插入图片描述
  • 结点–>即树的数据元素
  • 结点的度–>结点挂接的子树数( 有几个直接后继就是几度 )
  • 结点的层次–>从根到该结点的层数( 根结点算第一层 )
  • 终端结点–>即度为 0 的结点,即叶子
  • 分支结点–>除树根以外的结点( 也称为内部结点)
  • 树的度–>所有结点度中的最大值( Max(各结点的度》)
  • 树的深度(或高度)–>所有结点中最大的层数( Max(各结点的层次))
    上图中的结点数= 13,树的度= 3,树的深度= 4

2. 树的表示法

2.1 图形表示法

事物之间的逻辑关系可以通过数的形式很直观的表示出来,如下图:
在这里插入图片描述

2.2 广义表表示法

在这里插入图片描述
用广义表表示法表示上图:
中国( 河北( 保定,石家庄 ),广东( 广州,东莞 ),山东( 青岛,济南 ) )
根作为由子树森林组成的表的名字写在表的左边。

3. 树的存储

前面我们学习了顺序存储链式存储,以下面的树为例,如何进行存储呢?也可以使用顺序存储:A,B,C,D...M,放到数组中,但是你不知道谁是谁儿子和爹吗?
在这里插入图片描述

3.1 双亲表示法:保存父节点关系

了解即可

struct Node {int data; //节点值int parent; //父节点下标
}

为了找到某一个节点的孩子是谁,需要进行遍历查看父节点信息。
上面的方法是站在爹妈的角度去看的

3.2 孩子表示法

以孩子成长的角度来看就是孩子表示法。以链式去保存,需要保存孩子的信息,但是孩子数量不固定,对于ChildNode*就不知道定义几个指针了,定义的多了就会产生多余指针。

可以通过链表将孩子节点进行保存,这样就可以通过链表将节点进行保存

struct ChildNode {int data; //节点值ChildNode*
}
childNode D;
D.ChildNode*;

3.3 左孩子右兄弟表示法

不管是什么样的树,都可以转换为二叉树

第一个节点A,左孩子为B,右兄弟没有,B的左孩子E,右兄弟C,E的左孩子K,右兄弟F,K的左孩子没有,右兄弟L,到F,左孩子和右兄弟没有,到C,左孩子G,右兄弟D,D的左孩子H,右兄弟没有,到H,左孩子M,右兄弟I,I的左孩子没有,右兄弟J。

在这里插入图片描述
通过左孩子右兄弟之后就转换为这种树,每个节点有0到2个孩子,这种树称为二叉树。

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

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

相关文章

前端构建工具 webpack 笔记

1、了解 webpack 1、定义:本质上,webpack 是一个用于现代 JavaScript 应用程序的静态模块打包工具,当 webpack 处理应用它会在内部从一个或多个入口点构建一个依赖图(dependency graph),然后将你项目中所程序时,需的…

【javaSE】 反射与反射的使用

文章目录 🌲反射的定义🎍反射的用途🌴反射基本信息🍀反射相关的类🚩Class类(反射机制的起源 )🎈Class类中的相关方法 🚩反射示例🎈获得Class对象的三种方式🎈反射的使用 …

Activating More Pixels in Image Super-Resolution Transformer(HAT)超分

摘要 基于Transformer的方法在低级视觉任务(如图像超分辨率)上表现出令人印象深刻的性能。然而,我们发现这些网络只能通过归因分析利用有限的输入信息空间范围。这意味着Transformer的潜力在现有网络中仍未得到充分利用。为了激活更多输入像…

Spring 的创建和日志框架的整合

目录 一、第一个 Spring 项目 1、配置环境 2、Spring 的 jar 包 Maven 项目导入 jar 包和设置国内源的方法: 3、Spring 的配置文件 4、Spring 的核心 API ApplicationContext 4、程序开发 5、细节分析 (1)名词解释 (2&…

uboot 顶层Makefile-make xxx_deconfig过程说明三

一. uboot 的 make xxx_deconfig配置 本文接上一篇文章的内容。地址如下:uboot 顶层Makefile-make xxx_deconfig过程说明二_凌肖战的博客-CSDN博客 本文继续来学习 uboot 源码在执行 make xxx_deconfig 这个配置过程中,顶层 Makefile有关的执行思路。 …

STM32纯中断方式发送接收数据(串行通信;keil arm5;)

除了main文件其他文件均无修改,正常运行--在keil arm5内

AJAX学习笔记9 搜索联想自动补全

AJAX学习笔记8 跨域问题及解决方案_biubiubiu0706的博客-CSDN博客 其实就一个功能 搜索联想 自动补全 键盘按下事件keydown 键盘弹起事件keyup 做模糊查询 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><t…

第9节-PhotoShop基础课程-移动抓手缩放工具

文章目录 前言1. 移动工具1.移动工具1.自动选择&#xff08;图层和组&#xff09;2.显示变换控件 &#xff08;Shift 变换/ Ctrl 变换&#xff09;3.自由变换 Ctrl T &#xff08;Shift 变换/ Ctrl 变换&#xff09;4.对齐功能 2.画板工具 V1. 创建画板并作图2.导出画板 2.路…

59、SpringBoot 自定义JSON的序列化器和反序列化器

Serialization(序列化)&#xff1a; 将java对象以一连串的字节码保存在磁盘文件中的过程&#xff0c;也可以说是保存java对象状态的过程。序列化可以将数据永久保存在磁盘上(通常保存在文件中)。 deserialization(反序列化)&#xff1a; 将保存在磁盘文件中的java字节码重新转…

Jmx协议远程连接java服务器

注意&#xff1a;本例里&#xff0c;我用的是jdk17 通常用jdk自带的jconsole&#xff0c;或者想要功能强大点的使用visualVM 需要java服务器在启动的时候加上以下参数 -Dcom.sun.management.jmxremote 启用jxm远程连接-Djava.rmi.server.hostname10.1.3.99 指定jxm监听地址&…

python 自(1)定义变量 数据类型 判断数据类型 转换数据类型 算数运算符 复合运算符 比较运算符 逻辑运算符 赋值运算符

注释 # 注释 就是一个 # 也可以 ctrl / 也可以出来注释 命名规范 # 标识符 由字母 下划线 数字 组成 数字不能开头 # 不可以使用 关键字 # 严格区分大小写 定义变量 # 变量定义 重复利用 # 例如 cons 你好小周 print(cons) print(cons)print("你好小周") #这…

【经典小练习】JavaSE—拷贝文件夹

&#x1f38a;专栏【Java小练习】 &#x1f354;喜欢的诗句&#xff1a;天行健&#xff0c;君子以自强不息。 &#x1f386;音乐分享【如愿】 &#x1f384;欢迎并且感谢大家指出小吉的问题&#x1f970; 文章目录 &#x1f384;效果&#x1f33a;代码&#x1f6f8;讲解&#x…

每日一题 2596. 检查骑士巡视方案

难度&#xff1a;中等 很简单&#xff0c;从第 0 步开始模拟即可&#xff0c;唯一sb的就是测试用例中如果&#xff08;0&#xff0c;0&#xff09;处不为0的话就直接false&#xff0c;而不是去找0在哪 我的代码&#xff1a; class Solution:def checkValidGrid(self, grid: L…

【PowerQuery】Excel的PowerQuery的复制

在Excel中构建符合要求的PowerQuery连接之后&#xff0c;所有的PowerQuery 连接已经顺利的保存在Excel 工作簿当中&#xff0c;但是如何去查看已经保存的PowerQuery连接呢&#xff1f;图6.3 显示了查看PowerQuery连接。 Excel界面->数据页签->查询与连接 如果你的Power…

python求解一维弦振动方程

1、一维弦振动方程 2、差分公式及求解 import numpy as np import matplotlib.pyplot as plt l1 #长度 nx 101 #x方向网格节点数量 dx l/(nx-1) #空间网格步长 t6 #总时间 dt 0.01 # 时间步长 t_setnp.array([0.00,0.10,0.20,0.30,0.40,0.50,0.60]) #需要观察的时…

GO语言篇之发布开源软件包

GO语言篇之发布开源软件包 文章目录 GO语言篇之发布开源软件包新建仓库拉取到本地初始化项目编写代码提交代码发布引用软件包 我们写GO语言程序的时候难免会引用第三方的软件包&#xff0c;那么你知道别人是怎么发布自己的软件包吗&#xff0c;别急&#xff0c;这篇博客教你怎么…

如何使用 Node.js和Express搭建服务器?

如何使用NodeJs搭建服务器 1. 准备工作1.1 安装Node.js 2. 安装express2.1 初始化package.json2.2 安装express2.3 Express 应用程序生成器 欢迎使用Markdown编辑器新的改变功能快捷键合理的创建标题&#xff0c;有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段…

geohash学习

geohash编解码 import ("github.com/mmcloughlin/geohash" )func Test_Demo(t *testing.T) {// 编码经纬度到 geohash 字符串lat, lon : 40.7128, -74.0060 // 纽约市的位置geoHash : geohash.Encode(lat, lon) // geohash 字符串fmt.Println(geoHash) …

Spring WebFlux详解

Spring 框架中包含的原始 Web 框架 Spring Web MVC 是专门为 Servlet API 和 Servlet 容器而设计的。后来在 5.0 版本中加入了 reactive 栈的 Web 框架 Spring WebFlux。它是完全非阻塞的&#xff0c;支持 Reactive Streams 背压&#xff0c;并在 Netty、Undertow 和 Servlet 容…

lv4 嵌入式开发-1 Linux文件IO

目录 1 文件的概念和类型 2 如何理解标准IO 3 流(FILE)的含义 3.1 流 3.2 文本流和二进制流 3.3 流的缓冲类型 4 小结 5 缓存区实验 1 文件的概念和类型 概念&#xff1a;一组相关数据的有序集合 文件类型&#xff1a; 常规文件 r 目录文件 d 字符设备文件 …