数据结构和算法-树和二叉树的定义和基本术语和性质

news2025/1/10 10:48:03

文章目录

  • 树的基本概念和相关术语
    • 相关的应用
    • 节点间的关系描述
    • 节点,树的属性描述
    • 有序树vs无序树
    • 树vs森林
    • 小结
  • 树的相关性质
    • 考点1
    • 考点2
    • 考点3
    • 考点4
    • 考点5
    • 考点6
    • 小结
  • 二叉树的相关概念和基本术语
    • 重要 (五种状态)
    • 特殊二叉树
    • 小结
  • 二叉树的相关性质
    • 二叉树考点1
    • 二叉树考点2
    • 二叉树考点3
    • 完全二叉树考点1
    • 小结

树的基本概念和相关术语

在这里插入图片描述

当存在非根节点有两个前驱或者没有前驱时,都不构成树

在这里插入图片描述
任何非空树可以看作根节点和不相交的子树构成(子树可为空树)

在这里插入图片描述

相关的应用

在这里插入图片描述

节点间的关系描述

  • 祖先节点:节点以上的节点都是祖先节点
  • 子孙节点:节点一下的节点都是子孙节点
  • 双亲节点(父节点):节点的上一个节点是双亲节点
  • 兄弟节点:双亲节点相同的子孙节点
  • 堂兄弟节点:emmm有点不好说,就是同一层的节点但不包括兄弟节点,如图中的 你 G H I J

在这里插入图片描述

节点的深度(层次)可以从零开始,也可以从一开始,默认是一(高度也一样)
高度和深度相反,从字面意思应该就能理解

节点,树的属性描述

在这里插入图片描述

有序树vs无序树

有序无序看存啥吧,看你想用左右位置反映啥关系不
在这里插入图片描述

树vs森林

树的节点可以为0,即空树,森林也可以由0棵树构成,即空森林
在这里插入图片描述

小结

在这里插入图片描述

树的相关性质

树的节点数=树的所有节点的度数+1
可以这么理解
某层节点的度数和相当于下一层节点的节点数,如下图
有四层时,一二三四层的度数和相当于二三四层的节点数和(四层的度数和为零),但树的节点数还包括根节点,而一二三四层的度数和没有包括第一层的节点数,而第一层节点数为1。
所以树的节点数=树的所有节点的度数+1

考点1

在这里插入图片描述

考点2

m叉树可以为空树
在这里插入图片描述

考点3

在这里插入图片描述

考点4

在这里插入图片描述

考点5

在这里插入图片描述
这里是先设高度最小为h则可以列出此时对应的节点数应该是大于前h-1层最多的节点数的,不然不可能还会有第h层嘛,然后此时n不可能比h层最多的节点数还多嘛,不然就有h+1层了,可以列出不等式,化简。

最后的话因为h是整数,h又必须大于图中的那个log啥的,h又要求最小,所以那个log啥的得向上取整就是h的最小值

考点6

在这里插入图片描述

小结

在这里插入图片描述

二叉树的相关概念和基本术语

二叉树有序且每个节点至多两课子树(可为空子树)
在这里插入图片描述

重要 (五种状态)

在这里插入图片描述

特殊二叉树

完全二叉树:节点与对应的满二叉树节点一一对应
完全二叉树最多只有一个度为1的节点,如果有两个,则意味这两个度为1的节点的孩子之间相隔了一个节点,那么将不满足节点与对应的满二叉树节点一一对应的条件
在这里插入图片描述

如果完全二叉树某节点只有一个孩子,那么一定是左孩子

二叉排序树即左孩子上存储的值小于父节点上存储的值小于右孩子上存储的值
在这里插入图片描述
当二叉排序树是平衡二叉树时,那么搜索的深度更小,效率更高。因为比较次数少了

在这里插入图片描述

小结

在这里插入图片描述

二叉树的相关性质

总度数=度为1的结点数1+度为2的结点数2

二叉树考点1

在这里插入图片描述

二叉树考点2

在这里插入图片描述

二叉树考点3

在这里插入图片描述

完全二叉树考点1

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

小结

在这里插入图片描述

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

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

相关文章

Java - Stream Filter 多条件筛选过滤

Java Stream流中Filter用于通过设置的条件过滤出元素 ,示例如下: List strings Arrays.asList(“abc”, “”, “bc”, “efg”, “abcd”,"", “jkl”);List filtered strings.stream().filter(string -> !string.isEmpty()).collect(C…

220v转5v3.3v稳压芯片WD5201

WD5201是一款高效、低功耗、低成本的220V转5V/3.3V/2.7V稳压芯片,具有高输出精度和宽输入电压范围。它采用了先进的电路设计和制造工艺,具有快速动态响应和优异的负载调节性能。 WD5201采用了SOP-8封装,易于集成和适用于各种智能家电设备。它…

Python实现DDos攻击实例详解

文章目录 SYN 泛洪攻击Scapy3k 基本用法代码实现DDos 实现思路argparse 模块socket 模块代码实现Client 端程序测试后记关于Python技术储备一、Python所有方向的学习路线二、Python基础学习视频三、精品Python学习书籍四、Python工具包项目源码合集①Python工具包②Python实战案…

了解静态测试?

静态测试是一种软件测试方法,它主要通过分析软件或代码的静态属性来检查潜在的问题和缺陷,而无需实际执行程序。这种测试方法侧重于检查源代码和其他软件文档,以发现错误并提高软件质量。 为什么要做静态测试? 提前发现和修复错…

使用安卓的IMU数据进行 行人航位推算(PDR)推算步长 附python 代码

加速度计数据、陀螺仪数据、重力传感器数据、姿态仰角数据。 数据分析与定位轨迹生成主要使用Python离线完成。 示意图 show_steps函数:显示垂直方向合加速度与步伐波峰分布 show_gaussian函数:查看数据在一定范围内的分布情况 step_stride函数:步长推算函数 step_counte…

【Python】遍历电脑中的所有文件

通过os模块中的os.walk()遍历电脑指定路径的所有文件及大小: import osdef traverse_files(path):file_path_list[]file_size_list[]for root, dirs, files in os.walk(path):for file in files:file_path os.path.join(root, file)file_path_list.append(file_pa…

探索容灾架构演进之路,从单点到异地多活

1. 挑战与变革 在公司发展初期,业务发展和用户增长是首要关注的焦点。然而,随着业务规模不断扩大,用户数量逐渐攀升,应用稳定性的重要性也变得愈发凸显。在这个演进过程中,传统架构下的应用部署模式开始显露出多方面的…

时间序列预测实战(十九)魔改Informer模型进行滚动长期预测(科研版本,结果可视化)

论文地址-> Informer论文地址PDF点击即可阅读 代码地址-> 论文官方代码地址点击即可跳转下载GIthub链接 个人魔改版本地址-> 文章末尾 一、本文介绍 在之前的文章中我们已经讲过Informer模型了,但是呢官方的预测功能开发的很简陋只能设定固定长度去预测…

Unity中Shader的BRDF解析(二)

文章目录 前言一、回顾一下上一篇的结尾在这里插入图片描述 二、我们来解析一下 UNITY_PBS_USE_BRDF1(高配)1、迪士尼BRDF原则2、迪士尼的漫反射函数3、参数:perceptualRoughness(感性的粗糙度)4、参数:hal…

Linux:通过VMWare,定制化Linux系统

一、原理图 二、新增磁盘(对应上图sdb盘) 三、挂载磁盘 主要是四步:查看磁盘,分区磁盘,格式化磁盘,挂载磁盘 1、查看磁盘 2、分区磁盘 3、格式化磁盘 4、挂载磁盘 创建两个备用目录,用于磁盘…

Rocket mq namesrv源码分析

NameServer 作为注册中心,提供路由注册、路由踢出、路由发现功能,舍弃强一致,保证高可用,集群中各个节点不会实时通讯,其中一个节点下线之后,会提供另外一个节点保证路由功能。 启动入口 org.apache.rock…

鸿蒙应用开发-初见:ArkUI

编程范式:命令式->声明式 以一个卡片的实现做下讲解 命令式 简单讲就是需要开发用代码一步一步进行布局,这个过程需要开发全程参与。 Objective-C UIView *cardView [[UIView alloc] init]; cardView.backgroundColor [UIColor whiteColor]; ca…

文生视频的发展史及其原理解析:从Gen2、Emu Video到SVD、PixelDance

前言 考虑到文生视频开始爆发,比如 今年,作为最早探索视频生成领域的领头羊之一,Runway 先后发布Gen-1、Gen-2 模型(runway也是Stable Diffusion 开发商之一),特别是Gen-2带来了电影级别的高清晰度,令人瞩目&#xf…

Vue3-pnpm包管理器创建项目

一些优势:比同类工具快2倍左右、节省磁盘空间 官网:pnpm - 速度快、节省磁盘空间的软件包管理器 | pnpm中文文档 | pnpm中文网 npm升级到yarn再升级到pnpm(速度更快) 安装方式:npm install -g pnpm 创建项目&#…

C++之常用的拷贝和替换算法

C之常用的拷贝和替换算法 copy #include<iostream> using namespace std; #include<vector> #include<algorithm>void Myptint(int val) {cout << val << " "; }void test() {vector<int> v;for (int i 0; i < 10; i){v.pus…

波奇学C++:C++11的新特性

列表初始化 #include<iostream> using namespace std; struct A {int _x;int _y; }; int main() {// 三种方式等价&#xff0c;并且可以省略int x 1;int y { 2 };int z{ 3 };return 0; } {}按声明顺序初始化类成员变量 A p{ 1,2 }; cout << p._x; //1 cout &…

数字化转型导师坚鹏:BLM保险公司数字化转型战略培训圆满结束

在数字化转型背景下&#xff0c;为了落实监管政策《关于保险公司业保险业数字化转型的指导意见》&#xff0c;充分认识到学习保险公司数字化转型战略的价值和重要性&#xff0c;特别举办《2023年保险公司数字化转型战略专题培训班》。为了改变大家的认知&#xff0c;为了拓宽大…

销售漏斗是什么?

销售漏斗是一个重要的销售管理工具&#xff0c;它可以帮助销售人员更好地管理和跟踪潜在客户。销售漏斗模型通常被广泛应用于B2B销售中&#xff0c;它可以将销售过程细分为多个阶段&#xff0c;例如潜在客户、初步沟通、方案报价、谈判和签约等。 销售漏斗有以下作用&#xff…

洗地机应该怎么选?希亦、必胜、米博、添可、小米洗地机实测推荐

作为一个常年测评智能家居的博主&#xff0c;关于洗地机的测评使用这些年也积累了不少的体验感受。以至于常被周边的朋友问到&#xff0c;洗地机到底是不是真的好用&#xff1f;洗地机有什么优点吗&#xff1f;选购的时候应该怎么选呢&#xff1f;洗地机什么牌子比较好呢&#…

Spring Data Redis切换底层Jedis 和 Lettuce实现

1 简介 Spring Data Redis是 Spring Data 系列的一部分&#xff0c;它提供了Spring应用程序对Redis的轻松配置和使用。它不仅提供了对Redis操作的高级抽象&#xff0c;还支持Jedis和Lettuce两种连接方式。 可通过简单的配置就能连接Redis&#xff0c;并且可以切换Jedis和Lett…