数据结构——5.4 树、森林

5.4 树、森林

  • 概念

在这里插入图片描述
在这里插入图片描述

  1. 树的存储结构

    1. 双亲表示法

    2. 孩子表示法

    3. 孩子兄弟表示法(二叉树表示法):

      二叉树每个结点有三个变量

      ① 二叉树结点值:原树结点的值

      ② 二叉树左孩子:原树结点的最左孩子

      ③ 二叉树右孩子:原树结点的紧邻右兄弟

      该二叉树有一个特点:根节点只有左子树

  2. 森林和二叉树的转换

    1. 把森林中每一棵树都转换成二叉树(根节点只有左子树)

    2. 相邻树的根节点作为左右兄弟,从而可以填补作为各二叉树的右子树

在这里插入图片描述
在这里插入图片描述

  1. 树和森林的遍历

    1. 树的遍历

      1. 先根遍历:先访问根节点,再依次从左至右先根遍历子树(即第一次路过就标记)

        (与该树对应二叉树的先序序列相同)(深度优先遍历)

      2. 后根遍历:先对各个子树对后根遍历,再访问根节点(即第三次路过才标记)

        (与该树对应二叉树的中序序列相同)(深度优先遍历)

      3. 层次遍历:(用队列辅助实现)每次结点出队,就将其孩子结点从左至右入队(广度优先遍历)

    2. 森林的遍历

      1. 先序遍历:从左至右先根遍历各个树(与该森林对应二叉树的先序序列相同)

      2. 中序遍历:从左至右后根遍历各个树(与该森林对应二叉树的中序序列相同)

在这里插入图片描述

  • 理解
  1. 二叉链表存储森林时,根节点的右节点为森林左起第二棵的根,森林可能只有一棵树,因此根节点的右节点可能为空

  2. 森林转换成二叉树后,二叉树的左子为森林结点的左孩子,右子为森林结点的右兄弟,左左子,右右兄。

  3. 如果两个结点是兄弟关系,那么必定有一条右直线连接两个结点,否则不是

  4. 树的重要性质:n个结点的树,有n-1条边

  5. 森林的重要性质:n棵树的森林,有m个结点,则有m-n个边。

  • 技巧
  1. 二叉链表存储森林时,根节点的右节点为森林左起第二棵的根,森林可能只有一棵树,因此根节点的右节点可能为空

  2. 森林原有n个非终端结点,二叉树没有右子树的结点,即为没有右兄弟的结点,共有:(n+1个)(右指针域为空)

    1. 每个非终端结点的最右孩子没有右兄弟(n个)

    2. 森林最右树的根节点没有右子树(1个)

  3. 森林或树的叶结点数=二叉树左子树为空结点数

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

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

Acwing 5469. 有效点对【正难则反+巧妙选择根节点】

原题链接:https://www.acwing.com/problem/content/5472/ 题目描述: 给定一个 n 个节点的无向树,节点编号 1∼n。 树上有两个不同的特殊点 x,y,对于树中的每一个点对 (u,v)(u≠v),如果从 u 到 v 的最短路径需要经过…

《统计学简易速速上手小册》第2章:数据探索与可视化(2024 最新版)

文章目录 2.1 数据清洗和预处理2.1.1 基础知识2.1.2 主要案例:电商平台的顾客购买历史数据清洗2.1.3 拓展案例 1:社交媒体用户行为的数据清洗2.1.4 拓展案例 2:金融交易数据的预处理 2.2 探索性数据分析(EDA)2.2.1 基础…

项目02《游戏-13-开发》Unity3D

基于 项目02《游戏-12-开发》Unity3D , 任务 :宠物系统 及 人物头像血条 首先在主面板MainPanel预制体中新建一个Panel, 命名为PlayerInfo 新建Image,作为头像 新建Slider,作为血条 对Panel组件添加一个水…

Java核心设计模式:代理设计模式

一、生活中常见的代理案例 房地产中介:客户手里没有房源信息,找一个中介帮忙商品代购:代理者一般有好的资源渠道,降低购物成本(如海外代购,自己不用为了买东西出国) 二、为什么要使用代理 对…

编程揭秘刘谦春晚魔术(约瑟夫环问题Josephus)

哈喽~各位过年好哇! 相信大家应该都看了春晚刘谦表演的魔术吧,大家当时有没有跟着做成功呢,其实背后的原理很简单,现在我们来逐句分析,一起探索其中的原理吧! 首先,有四张牌假设为1&#xff0…

【Rust】——猜数游戏

🎃个人专栏: 🐬 算法设计与分析:算法设计与分析_IT闫的博客-CSDN博客 🐳Java基础:Java基础_IT闫的博客-CSDN博客 🐋c语言:c语言_IT闫的博客-CSDN博客 🐟MySQL&#xff1a…

MySQL篇----第十七篇

系列文章目录 文章目录 系列文章目录前言一、对于关系型数据库而言,索引是相当重要的概念,请回答有关索引的几个问题二、解释 MySQL 外连接、内连接与自连接的区别三、Myql 中的事务回滚机制概述前言 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分…

redis之布隆过滤

目录 1、redis之布隆过滤 2、布隆过滤器原理 3、布隆过滤器使用步骤 初始化bitmap 添加占坑位 判断是否存在圜 1、redis之布隆过滤 布隆过滤:有一个初值都为0的bit数组和多个哈希函数构成,用来快速判断集合中是否存在某个元素。目的:减…

顶级思维方式——认知篇三(财富与金钱)

目录 1、 什么是财富/财富的定义? 2、财富的影响 3、 财富意味着什么? 4、财富与幸福的关系 5、物质财富如何使用才有实际意义? 6、金钱的运作方式 7、【物质财富自由】后的选择 1、 什么是财富/财富的定义? 财富是一个多维…

c++之说_14|左值引用与右值引用

提起左右值引用我就头疼 左值: 1、在内存中开辟了空间的便叫左值 2、左值不一定可以赋值 如字符串常量 3、左值可以取地址 右值: 1、在内存中没有开辟空间的 2、右值无法取地址 如: 立即数(1,2,3…

移动端web开发布局

目录 flex布局: flex布局父项常见属性: flex布局子项常见属性: REM适配布局: 响应式布局: flex布局: 需要先给父类盒子设置display:flex flex是flexiblebox的缩写,意为"弹…

面试经典150题——三数之和

​"The road to success and the road to failure are almost exactly the same." - Colin R. Davis 1. 题目描述 2. 题目分析与解析 2.1 思路一——暴力方法 因为三个数相加为0,那么说明其中两个加数的和与另一个加数为相反数则满足题意。所以可以得到…

猫头虎分享已解决Bug || IndexError: index 3 is out of bounds for axis 0 with size 3

博主猫头虎的技术世界 🌟 欢迎来到猫头虎的博客 — 探索技术的无限可能! 专栏链接: 🔗 精选专栏: 《面试题大全》 — 面试准备的宝典!《IDEA开发秘籍》 — 提升你的IDEA技能!《100天精通鸿蒙》 …

解决挂梯子 无法正常上网 的问题

方法: 打开 控制面板 👉 网络和Internet 👉 Internet选项 👉 连接 👉 局域网设置 👉 代理服务器 👉 取消选项 有问题可参考下图

案例:三台主机实现 级联复制

介绍:级联复制架构 级联复制架构 是一种特殊的主从结构,之前聊到的几种主从结构都只有两层,但级联复制架构中会有三层,关系如下: 也就是在级联复制架构中,存在两层从库,这实际上属于一主多从架…

Failed to construct ‘RTCIceCandidate‘ sdpMid and sdpMLineIndex are both null

最近在搞webrtc,在编写函数处理远端传递来的candidate时报错了,具体信息如下。国内关于webrtc的资料很少,所以去国外社区转了一圈,回来记录一下报错的解决方案 其实这个bug也好解决,根据报错信息可以判断是RTCIceCand…

C语言第二十二弹---指针(六)

✨个人主页: 熬夜学编程的小林 💗系列专栏: 【C语言详解】 【数据结构详解】 指针 1. 回调函数是什么? 2、qsort使用举例 2.1、使用qsort函数排序整型数据 2.2 使用qsort排序结构体数据 3、qsort函数的模拟实现 总结 1. 回…

龙年,大吉

(1) 没有成功的企业,只有时代的企业。这就是人们老说的:天道酬勤。虽然这句话被人说滥了,虽然这句话被人说到反感了,但事实就是这样。 得道者多助。 (2) 人有三大运、三小运。 三大运…

Python基础语法(内置Python, pycharm配置方式)

一.工具安装与配置 1.Python解释器的安装 官网网址:https://www.python.org/ 选择downloads即可(Windows用户点击Windows, 苹果用户点击macOS) 找到最新版本, 并选择 Download Windows installer (64-bit) 下载完成后可在得到一个安装包进行安装(安装时间较长) 安装完成后…

【JMX】JAVA监控的基石

目录 1.概述 2.MBean 2.1.Standard MBean 2.2.Dynamic MBean 2.3.Model Bean 2.4.Dynamic MBean和Model Bean的区别 2.5.MXBean 2.6.Open Bean 3.控制台 1.概述 什么是JMX,首先来看一段对话: Java Management Extensions(JMX&#…