C树和森林的研究学习随记【一】

news2024/11/15 23:30:20

文章目录

  • 树与森林
  • 树结构初识
    • 树基本的相关概念
    • 森林
    • 二叉树(Binary Tree)
      • 满二叉树【饱满】
      • 完全二叉树【少了叶子的满二叉树】
      • 总结
      • 树和森林的转换
      • 快速转换技巧
      • 森林转化为二叉树
      • 分辨
      • 二叉树的五大性质

树与森林

  • 树是一种的数据结构。顾名思义,类似于我们生活中的树一样。【具体一点就是一对多的数据结构】

树结构初识

在这里插入图片描述

  • 从最上面的根节点的节点开始像下面进行延申,更多的节点,这种结构就称为树(Tree)
  • 注意分支只能向后单向延申,不能与其他分支上的结点相交。

树基本的相关概念

术语解释
根节点位于最上面的结点。
每个节点连接的子节点数目(分支的数目)。
树的度一棵树中各个结点度的最大值。
子树每个节点延伸下去的下一个节点都可以称为一棵子树。
结点的层次(Level)按照从上往下的顺序,树的根节点的层次为1,每向下一层+1
树的层次(Depth)整棵树中所有结点的最大层次。
子节点(Child)与当前结点直接向下相连的结点
父节点(Parent)与当前结点直接向上连接的结点
兄弟结点(Sibling)两个结点的父节点相同
祖宗结点(Ancestor)从根节点开始一直到某个结点的整条路径的所有结点,都是当前结点的祖宗节点
叶子结点度为0的结点【一般位于分支的最末端】
分支结点度为1或2的非根节点

森林

  • 一片森林是由很多课树构成。
    在这里插入图片描述
  • 各个树之间互不连接。

二叉树(Binary Tree)

  • 二叉树是一种特殊的树,它的度最大只能为2。
    在这里插入图片描述
  • ***二叉树的结点的子树是有左右之分的,不能颠倒顺序。***A左边的子树为左子树,A右边的树为右子树。
  • 二叉树的五种基本形态
    在这里插入图片描述

满二叉树【饱满】

  • 满二叉树:所有的分支结点都存在左子树和右子树,且叶子结点都在同一层。
  • 整棵树都是很饱满的,没有度为1的结点。
    在这里插入图片描述

完全二叉树【少了叶子的满二叉树】

  • 只有最后一层有空缺,并且所有的叶子节点是按照从左到右的顺序排列的。
    在这里插入图片描述

总结

  • 一颗满二叉树一定是一个课完全二叉树。完全二叉树一定不是满二叉树【但完全二叉树是一颗少了叶子的满二叉树】。

树和森林的转换

  • 普通树转换为二叉树的转换规则
    • 孩子结点->左子树结点(左孩子)
    • 兄弟节点->右子树结点(右兄弟)
  • 规律:一颗普通树转化为二叉树后2,跟结点一定没有左子树。
  • 普通树
    在这里插入图片描述
  • 转换后的二叉树
    在这里插入图片描述

快速转换技巧

  • 第一步:直接将从最左端开始将所有的兄弟节点连接起来。
    在这里插入图片描述
  • 第二步:然后擦除所有结点除了最左边结点以外的连线。
    在这里插入图片描述
  • 第三步:所有的黑色连线偏向左,橙色连线偏向右
    在这里插入图片描述

森林转化为二叉树

  • 第一步:先将森林中的所有普通树转化为二叉树。
  • 第二步:然后依次相连【右兄弟】
  • 森林
    在这里插入图片描述
  • 转化后的二叉树
    在这里插入图片描述
  • 连接每棵树时,都是从根节点的右边开始,不断向右连接。

分辨

  • 如果二叉树的根节点有右兄弟结点,则它是由森林转换而来。否则,它是由一棵树转换而来。

二叉树的五大性质

  • 性质一:对于一颗二叉树,第i层的最大结点数量为
    2 i − 1 2^{i-1} 2i1

  • 性质二:对于一颗深度为k的二叉树,可以具有的最大结点数量为:
    n = 2 0 + 2 1 + 2 2 + . . . + 2 k − 1 n=2^0+2^1+2^2+...+2^{k-1} n=20+21+22+...+2k1
    简化计算
    S n = a 1 × ( 1 − q n ) 1 − q = 1 × ( 1 − 2 k ) 1 − 2 = − ( 1 − 2 k ) = 2 k − 1 S_n=\frac{a_1\times(1-q^n)}{1-q}=\frac{1\times(1-2^k)}{1-2}=-(1-2^k)=2^k-1 Sn=1qa1×(1qn)=121×(12k)=(12k)=2k1

    • 结论:
      • 一颗深度为k的二叉树最大结点数量为 2 k − 1 2^k-1 2k1,结点的边数为 E = n − 1 E=n-1 E=n1
  • 性质三:【记忆】
    n 0 = n 2 + 1 n_0=n_2+1 n0=n2+1

    • 假设一颗二叉树中度为0、1、2的结点数量为 n 0 、 n 1 、 n 2 n_0、n_1、n_2 n0n1n2,由于一棵树二叉树中只有这三种类型的结点,可得结点总数:
      n = n 0 + n 1 + n 2 n=n_0+n_1+n_2 n=n0+n1+n2
    • 从二叉树的边数考虑,因为每个结点有且仪有一条边与具交结点相连,那么边数之和就可以表示为
      E = n 1 + 2 n 2 E=n_1+2n_2 E=n1+2n2
    • 度为1的结点有一条边,度为2的结点有两条边,度为0的结点没有,加在一起就是整棵二叉树的边数之和,可得
      E = n − 1 = n 1 + 2 n 2 n = n 1 + 2 n 2 + 1 E=n-1=n_1+2n_2 n=n_1+2n_2+1 E=n1=n1+2n2n=n1+2n2+1
    • 再结合第一个公式
      n 0 = n 2 + 1 n_0=n_2+1 n0=n2+1
  • 性质四:【记忆】

    • 完全二叉树除了最后一层有空缺外,其他层数都是饱满的,假设这模二叉树为满二叉树,那么根据我们前面得到的性质,假设层数为 k k k,那么结点数量为: n = 2 k − 1 n=2^k-1 n=2k1,根据完全二叉树的性质,最后一层可以满可以不满,那么一棵完全二叉树结点数 n n n满足:
      2 k − 1 − 1 < n < = 2 k − 1 2^{k-1}-1<n<=2^k-1 2k11<n<=2k1
    • 因为n肯定是一个整数,那么可以写为
      2 k − 1 < = n < = 2 k − 1 2^{k-1}<=n<=2^k-1 2k1<=n<=2k1
    • 现在我们只看左边的不等式,我们对不等式两边同时取对数,得到
      k − 1 < = l o g 2 n k-1<=log_2n k1<=log2n
    • 综上所述,一棵具有n个结点的完全二叉树深度为
      k = l o g 2 n + 1 k=log_2n+1 k=log2n+1
  • 性质五:

    • 一颗有n个结点的完全二叉树,由性质四得到深度为k=log2+1现在对于任意一个结点i,结点的顺序为从上往
      下,从左往右:
    • 对于一个拥有左右孩子的结点来说,其左孩子为 2 i 2i 2i,右孩子为 2 i + 1 2i+1 2i+1
    • 如果 i = 1 i=1 i=1,那么此节点为二叉树的根节点,如果 i > 1 i>1 i>1,那么其父节点为 ⌊ i / 2 ⌋ \lfloor i/2 \rfloor i/2
    • 如果 2 i > n 2i>n 2i>n,则结点 i i i没有左孩子
    • 如果 2 i + 1 > n 2i+1>n 2i+1>n,则结点i没有右孩子

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

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

相关文章

C++11标准模板(STL)- 算法(std::stable_sort)

定义于头文件 <algorithm> 算法库提供大量用途的函数&#xff08;例如查找、排序、计数、操作&#xff09;&#xff0c;它们在元素范围上操作。注意范围定义为 [first, last) &#xff0c;其中 last 指代要查询或修改的最后元素的后一个元素。 将范围内的元素排序&#…

m基于Simulink的高速跳频通信系统抗干扰性能分析

目录 1.算法描述 2.仿真效果预览 3.MATLAB部分代码预览 4.完整MATLAB程序 1.算法描述 信道为Rayleigh衰落信道下的性能分析和Nakagami-m衰落信道下的性能分析。本课题我们采用的仿真参数如下&#xff1a; simulink仿真模型如下所示&#xff1a; 跳频是最常用的扩频方式之一…

Hadoop笔记-01概述

文章目录1 什么是大数据&#xff1f;1.1 大数据计算模式及代表产品1.2 云计算与物联网1.2.1 云计算1.2.1.1 虚拟化1.2.1.2 分布式存储1.2.1.3 分布式计算1.2.1.4 多租户1.3 物联网1.3.1 识别和感知技术1.3.2 网络与通信技术1.3.3 数据挖掘与融合技术1.4 大数据与云计算、物联网…

正态分布,二维正态分布,卡方分布,学生t分布——概率分布学习 python

目录 基本概念 概率密度函数(PDF: Probability Density Function) 累积分布函数(CDF: Cumulative Distribution Function) 核密度估计&#xff08;(kernel density estimation&#xff09; 1.正态分布 概率密度函数&#xff08;pdf&#xff09; 正态分布累积分布函数(CD…

山东大学软件学院操作系统课程设计(2021秋季,nachos)实验6

一、实验内容 二、源码分析 1. 理解nachos单线程地址映射机制 Machine::Run()中调用Machine::OneInstruction(Instruction *instr)逐条执行可执行文件中的指令&#xff0c;执行指令过程中和获取下一条指令时如果访问内存&#xff0c;通过machine->ReadMem(…)/WriteMem(……

嵌入式开发学习之--用蜂鸣器来传递摩斯码

本篇文章致力于从开发的角度思考问题&#xff0c;而不是搞学术的东西。 文章目录前言一、项目概况1.1、项目需求1.2、项目来源1.3、项目开发环境1.4、项目意义二、开发步骤2.1、了解什么是摩斯码2.2、构建项目流程图2.3、找到合适的模板2.4、增加文件2.5、添加代码2.6、读入数据…

学生HTML个人网页作业作品 (水果商城HTML+CSS)

&#x1f380; 精彩专栏推荐&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 &#x1f482; 作者主页: 【主页——&#x1f680;获取更多优质源码】 &#x1f393; web前端期末大作业…

通过写循环判断对称数:将一个整型数逆置,我们判断逆置后的整型数如果和最初的数相等,那么它就是对称数,如果不相等,就不是对称数

将一个整型数逆置&#xff0c;我们判断逆置后的整型数如果和 最初的数相等&#xff0c;那么它就是对称数&#xff0c;如果不相等&#xff0c;就不是对称数#include <stdio.h>int main() {int i,j0;scanf("%d",&i);int ki;//备份写在scanf之后while(i){jj*1…

Dubbo入门实战(SpringBoot + Nacos)

本文主要介绍 Dubbo 3.0 整合 SpringBoot 的样例&#xff0c;这里使用 Nacos 作为注册中心&#xff0c;读者也可以使用 Zookeeper&#xff0c;项目结构为&#xff1a; interface-service&#xff1a;接口服务user-service-provider&#xff1a;服务提供者order-service-consume…

浅谈中小企业的供应商管理

一、供应商管理的概念 供应商管理&#xff0c;是在新的物流与采购经济形势下&#xff0c;提出的管理机制。现代管理学如MBA、EMBA等将其分为竞争式及双赢式两种模式。供应商管理是供应链采购管理中一个很重要的环节&#xff0c;它在实现准时化采购中有很重要的作用。供应商管理…

Linux | 进程间通信 | 匿名管道 | 命名管道 | 模拟代码实现进程通信 | 控制多子进程时的资源回收问题

文章目录进程通信的意义匿名管道通信原理管道的访问控制进程控制管道的特点命名管道进程通信的意义 之前聊进程时&#xff0c;讲过一个性质&#xff0c;即进程具有独立性&#xff0c;两个进程之间的交互频率是比较少的。就连父子进程也只是共享代码&#xff0c;修改父子进程中…

Bezier曲线与B-Spline曲线

贝塞尔曲线 一阶贝塞尔曲线P01P_0^1P01​由两个控制点P0P_0P0​和P1P_1P1​完全定义&#xff0c;相当于线性插值。随着ttt从0到1变化&#xff0c;贝塞尔点从P0P_0P0​移动到P1P_1P1​. P01(1−t)P0tP1,t∈[0,1]P_{0}^{1}\left( 1-t\right) P_{0}tP_{1}\quad,t\in[0,1] P01​(1−…

服务器是什么

服务器是什么 服务器是什么&#xff1a;服务器英文名称为“Server”&#xff0c;指的是网络环境下为客户机(Client)提供某种服务的专用计算机&#xff0c;服务器安装有网络操作系统(如Windows Server、Linux、Unix等)和各种服务器应用系统软件(如Web服务、电子邮件服务)&#…

操作系统:进程的创建(fork函数)、进程的替换(exec函数)、进程的阻塞(wait函数)、进程的终止(exit函数)、进程的挂起(sleep函数)

文章目录1.进程的创建2.进程的替换3.进程的阻塞4.进程终止5.进程的挂起1.进程的创建 ①调用fork函数的进程为父进程&#xff0c;调用后生成一个子进程&#xff1b; ②创建子进程成功时&#xff0c;父进程中fork函数的返回值是子进程的进程号PID&#xff1b; ③创建子进程失败时…

关于Java代码如何项目部署

在研究注解的时候会用到反射&#xff0c;在学习反射的时候会涉及到关于class文件的生成&#xff0c;以及Class文件是如何被执行的等一系列关于文件转换的问题&#xff0c;接下来就借助学习反射来学习一下项目整体部署的过程和每个阶段要生成的文件. 我们写的代码写完并测试之后…

粒子群算法求解电力系统环境经济调度+微电网调度(风、光、电动车、柴油机、主网)(Python代码实现)

目录 1 电力系统环境经济调度数学模型 2 改进粒子群算法解决 2.1 知识回顾 2.2 案例1——IEEE6节点 2.3 案例2——IEEE10 2.4 案例3——IEEE40 3 Python代码 1 电力系统环境经济调度数学模型 2 改进粒子群算法解决 2.1 知识回顾 先回顾一下相关知识点&#xff1a; *智…

打开网站出现Internal Server Error的原因和解决方法

打开网站出现Internal server error 500错误&#xff0c;通常是服务端出现一些未知异常&#xff0c;但是在检查的时候我们不能仅仅只是关注应用服务&#xff0c;而是要关注从服务端接收请求开始&#xff0c;一直到应用服务的整条链路。 程序文件中的权限问题导致Internal Serv…

正确的PMP®答题思路——让你考试更轻松

想要考取PMP的小伙伴们&#xff0c;大家现在复习的如何呢&#xff1f;是不是还在不断刷题呢&#xff1f;做题不单单需要充足的知识储备&#xff0c;更需要正确的答题思路&#xff0c;今天小编给大家整理了PMP考试答题的一些思路&#xff0c;想要考取PMP的小伙伴们快来看看吧&am…

Wireshark过滤器语法

1.官网地址 点击进入 2.捕获过滤器 使用捕获过滤器Wireshark只捕获满足过滤器条件的数据包进来。捕获过滤器采用BPF语法表达式&#xff0c;表达式由如下及部分组成: Dir 指明传输方向是前往还是来自 例如&#xff1a;src、dst Type 指出名字或数字所代表的意&#xff0c;例如…

SpringCloud微服务(七)——Bus服务消息总线

SpringCloud Bus动态刷新全局广播 SpringCloud Spring Cloud Bus配合Spring Cloud Config使用可以实现配置的动态刷新&#xff0c;通知一处&#xff0c;处处生效。而不用一个一个去通知。 Spring Cloud Bus是消息总线&#xff0c;广播通知都可以集成&#xff0c;不止用于实现…