当前位置: 首页 > news >正文

树与二叉树 总复习

一、树的定义

树是一个有n个(n>=0)结点的有限集合。

如果n=0,称为空树;

如果n>0,称为非空树,有且仅有一个特定的称为根Root的结点(无直接前驱)

如果n>1,除了根节点外,其他结点划分为m个互不相交的有限集合(记为T1、T2...TM),每个集合本身又是一棵树,称为根的子树(Sub-tree)。

每个结点肯定有唯一的前驱(除根节点外),但是可能有多个后继。

二、树的术语

结点:包含一个数据元素及若干指向其子树的分支

结点的度:结点拥有的子树个数,也即结点包含的分支个数

叶子结点(终端结点)

度为0的结点 {K,L,F,G,M,I,J}

分支结点()非终端结点

度不为0的结点 {A,B,C,D,E,H}

包含根结点

内部结点:除根之外的分支结点 {B,C,D,E,H}

孩子:结点的子树的根

双亲:孩子的直接前驱

兄弟:同一个双亲的其他孩子

子孙:以某结点为根的树中所有的结点

祖先:从该结点到根结点,经过所有分支结点

树的层次

根结点为第一层,根的孩子为第二层,依次类推。

深度:树中最大的层次

森林:互不相交的树的集合。对于树中每个结点而已,其子树的集合就是森林

二叉树  Binary Tree

每个结点最多只有两棵子树 最多两个孩子

二叉树的子树可以分成左右两个部分 称为左子树和右子树    

 二叉树的性质1

在二叉树的第i层上至多有2i-1个结点  

深度为k的二叉树至多有2^k-1个结点

如果二叉树终端结点数为n0,度为2的结点数为n2,则no=n2+1

证明思路:总结点数n=no+n1+n2

考察分支数B:除了根之外,所有的结点都有且只有一个分支指向它不同度的结点产生不同个数的分支 n=B+1

不同度的结点产生不同个数的分支B=n1+2n2

no=n2+1

五、满二叉树

一个深度为k且有2^^k-1个结点的二叉树

每层上的结点数都是最大数  可以自上而下、自左至右连续编号

完全二叉树  当且仅当每一个结点都与深度相同的满二叉树中编号从1到n的结点一一一对应的二叉树

叶子结点只在最大两层上出现

以任何一个结点为根结点,其左子树深度与右子树深度相等或大于1

具有n个结点的完全二叉树 其深度为log2n取整+1

七、二叉树的存储结构:顺序存储

用一组连续的存储单元依次自上而下,自左至右存储结点

对于一般二叉树,空结点的位置也要按照完全二叉树编号

八、二叉树的链式存储结构

1、二叉链表

采用数据域加上左右孩子的指针

2、二叉链表的定义

二叉链表的一个结点的可以用一个结构体表示,里面包含的成员有一个数据域,两个指针域

struct BiNode    binode: 双节点           node:节点

{

char data;

BiNode  *Ichild,*rchild;

}

3、二叉树的链式存储结构

只能双亲找孩子,孩子难以找到双亲

4、二叉树的链式存储结构

三叉链表

 遍历二茶树

根据访问根结点的次序

DLR

LDR

LRD

先序:

boid PreOrderTraverse(BinTree T)

{

if(T)

{

cout<<T->data;

PreOrderTraverse(T->IChild);

PreOrderTraverse()T->rChild):

先序中序、中序后序

都可以求出二叉树

而先序和后序不可以

因为不具备确定左右子树的能力。

树的存储结构

双亲表示法   找双亲容易找孩子难   

孩子表示法:最大的缺点就是空指针链域太多    有些结点有很多孩子 有些结点的孩子很少:结构不均衡          

n结点的树   度为d      多链表表示法中 空指针必有[(d-1)n+1]

 

 

 

树的路径:

路径:从树的一个结点到另一个结点之间的分支构成了两个结点之间的路径

路径长度:路径上的分支的数目

树的路径长度:从根结点到每个结点之间路径长度的和

如果结点权重不一样,我们可以计算带权路径长度

从结点到根结点之间的路径长度乘以该结点的权重

树的带权路径长度WPL    Weighted  path length

树中所有叶子结点的带权路径长度之和()度为0

相同的叶子结点数,叶子结点也具有相同的权重,但是不同的二叉树会产生不同的WOL

引出概念

树的带权路径长度WPL最小的二叉树被称为最优二叉树

Huffman  哈夫曼树

有什么special的place

权值最大的结点离根最近

权值最小的结点离根最远

 

 

有了编码

怎么解码

要能唯一解码对编码有什么要求

要求前缀编码

即任何一个字符编码都不是其他字符的前缀

Huffman是一种前缀编码

 

相关文章:

树与二叉树 总复习

一、树的定义 树是一个有n个&#xff08;n>0&#xff09;结点的有限集合。 如果n0&#xff0c;称为空树&#xff1b; 如果n>0&#xff0c;称为非空树&#xff0c;有且仅有一个特定的称为根Root的结点&#xff08;无直接前驱&#xff09; 如果n>1,除了根节点外&…...

window10安装MySQL数据库

准备好软件MySql的下载参考&#xff1a;(1137条消息) mysql下载与安装过程_weixin_40396510的博客-CSDN博客_mysql数据库下载安装(1137条消息) 安装MySQL的常见问题_二木成林的博客-CSDN博客_sc不是内部或外部命令,也不是可运行的程序解压要C盘&#xff08;自定义&#xff0c;本…...

羊了个羊游戏开发教程3:卡牌拾取和消除

本文首发于微信公众号&#xff1a; 小蚂蚁教你做游戏。欢迎关注领取更多学习做游戏的原创教程资料&#xff0c;每天学点儿游戏开发知识。嗨&#xff01;大家好&#xff0c;我是小蚂蚁。终于要写第三篇教程了&#xff0c;中间拖的时间有点儿长&#xff0c;以至于我的好几位学员等…...

SHA1详解

目录 一、介绍 二、与MD5的区别 1、对强行攻击的安全性 2、对密码分析的安全性 3、速度 三、应用 1、文件指纹 2、Git中标识对象 四、算法原理 1、填充消息 2、消息处理 3、数据运算 &#xff08;1&#xff09;链接变量 &#xff08;2&#xff09;步函数 一、介绍…...

Go并发介绍及其使用

1. goroutine Go语言通过go关键字来启动一个goroutine。注意&#xff1a;go关键字后面必须跟一个函数&#xff0c;不能是语句或者其他东西&#xff0c;函数的返回值被忽略。 goroutine有如下特性&#xff1a; go的执行是非阻塞的&#xff0c;不会等待。go后面的函数的返回值…...

小米手机屏幕解锁技巧精选

手机锁是一种保护存储的用户数据和信息的方法。存储在锁定手机中的所有信息比任何人都可以访问的手机安全得多。但有时&#xff0c;如果用户忘记了这些屏幕锁定&#xff0c;可能会造成麻烦。在此博客中&#xff0c;我们将帮助用户了解如何解锁小米手机。 什么时候需要解锁小米手…...

「SDOI2009」HH去散步

HH去散步 题目限制 内存限制&#xff1a;125.00MB时间限制&#xff1a;1.00s标准输入标准输出 题目知识点 动态规划 dpdpdp矩阵 矩阵乘法矩阵加速矩阵快速幂 思维 构造 题目来源 「SDOI2009」HH去散步 题目 题目背景 HH 有个一成不变的习惯&#xff0c;喜欢在饭后散步…...

用上Visual Studio后,我的世界游戏的构建时间减少了一半

今天我们讲述一个使用 Visual Studio 提升工作效率的案例。 我的世界(Minecraft) 游戏开发商 Mojang Studios 近日联系了 Visual Studio C 团队&#xff0c;因为他们需要将 C 开发扩展到新平台&#xff08;Linux&#xff09;&#xff0c;同时还希望保留他们现有的技术基础&…...

34、基于51单片机锂电池电压电流容量检测仪表LCD液晶显示 原理图PCB程序设计

方案选择 单片机的选择 方案一&#xff1a;AT89C52是美国ATMEL公司生产的低电压&#xff0c;高性能CMOS型8位单片机&#xff0c;器件采用ATMEL公司的高密度、非易失性存储技术生产&#xff0c;兼容标准MCS-51指令系统&#xff0c;片内置通用8位中央处理器(CPU)和Flash存储单元…...

【Java基础】泛型(一)-基础使用

本文以Java的官方文档为参考&#xff0c;辅以代码示例&#xff0c;尽可能详尽的叙述泛型的每一个特性 什么是泛型 泛型&#xff08;Generics&#xff09;也称为参数化类型&#xff08;parameterized types&#xff09;&#xff0c;也就是将类型本身作为接口、类、方法中的参数…...

学Python不会不知道NumPy计算包吧,带你五分钟看懂NumPy计算包

从今天我们就开始进入 Python 数据分析工具的教程。 前段时间数据分析和Python都讲了一点点&#xff0c;但是Python的数据库&#xff0c;讲的少了点&#xff0c;所以接下来就讲讲这些重要的常用数据库吧&#xff01;&#xff01;&#xff01; Python 数据分析绝对绕不过的四个…...

积水内涝监测——埋入式积水终端设备介绍

一、设备概述 埋入式积水终端是针对城市内涝推出的积水信息监测采集设备&#xff0c;采用超声波传感技术&#xff0c;对积水的深度进行精确的测量。产品能够在低温、腐蚀环境下可靠运行本产品特别适用于智慧城市中&#xff0c;对城市道路、社区低洼处的积水进行实时监测上报到…...

Kafka的日志同步

首先介绍下LEO和HW LEO&#xff1a; 即LogEndOffset&#xff0c;表示该副本下次日志记录的偏移量HW&#xff1a;即HighWatermark&#xff0c;高水位线&#xff0c;是所有ISR副本集合中的LEO最小值上图中&#xff0c;如果此时三个副本都在ISR集合中&#xff0c;那么此时他们的LE…...

【Mybatis源码解析】mapper实例化及执行流程源码分析

文章目录简介环境搭建源码解析基础环境&#xff1a;JDK17、SpringBoot3.0、mysql5.7 储备知识&#xff1a;《【Spring6源码・AOP】AOP源码解析》、《JDBC详细全解》 简介 基于SpringBoot的Mybatis源码解析&#xff1a; 1.如何对mapper实例化bean 在加载BeanDefinition时&a…...

分布式文件管理系统(MinIO)

1.去中心化&#xff0c;每个点是对等的关系&#xff0c;通过Ngix对负载做均衡工作。 好处&#xff1a; 能够避免单点故障&#xff0c;将多块硬盘组成一个对象存储服务。 2. 使用纠删编码技术来保护数据&#xff0c;是一种回复丢失和损坏的数据的数学算法&#xff0c;他将数据分…...

Springcloud-配置中心config

一、添加依赖<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-config-server</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId&…...

[项目篇] 音乐播放器开发报告

文章目录1. 项目描述:2. 项目上线展现&#xff1a;3. 项目具体实现&#xff1a;1. 登录2. 注册3.退出系统4.添加音乐4.1前后端交互约定4.2上传文件业务逻辑&#xff1a;4.3创建model包中的music类4.4在MusicMapper接口中&#xff0c;声明insertMusic抽象方法4.5在mybatis包中添…...

Spring Cloud Alibaba--gateway微服务详解之网关(二)

1、网关介绍 上篇对微服务中的nacos注册中心进行集成讲解。nacos主要作用是管理多服务之间复杂关系的组件。微服务是非常庞大且问题突出的架构&#xff0c;HTTP协议具有跨源资源共享 (CORS) Cross- Origin Resource Sharing机制&#xff0c;而处于安全考虑往往前端架构都会对跨…...

Zynq非VDMA方案实现视频3帧缓存输出,无需SDK配置,提供工程源码和技术支持

目录1、前言2、VDMA的不便之处3、FDMA取代VDMA实现视频缓存输出4、Vivado工程详解5、上板调试验证并演示6、福利&#xff1a;工程代码的获取1、前言 对于Zynq和Microblaze的用户而言&#xff0c;要想实现图像缓存输出&#xff0c;多半要使用Xilinx推荐的VDMA方案&#xff0c;该…...

血液透析过滤芯气密性检测装置中的高精度多段压力控制解决方案

摘要&#xff1a;针对目前血液过滤芯气密性检测过程中存在的自动化水平较低、多个检测压力之间需人工切换和压力控制精度较差的问题&#xff0c;为满足客户对高精度和自动化气密性检测的要求&#xff0c;本文提出了相应的解决方案。解决方案的主要特点是全过程的可编程压力控制…...

PDF加密如何批量解除?快来了解下这个方法

在现代办公环境中&#xff0c;PDF文档的使用非常普遍。然而&#xff0c;由于一些安全需求&#xff0c;有时候PDF文档会被加密&#xff0c;使得只有授权人员可以查看或修改它。但是&#xff0c;如果您需要对许多加密PDF文档进行操作&#xff0c;逐个解密这些文档可能非常费时费力…...

C++——哈希4|布隆过滤器

目录 布隆过滤器 完整代码 布隆过滤器应用 布隆过滤器的查找 布隆过滤器删除 布隆过滤器优点 布隆过滤器缺陷 布隆过滤器海量数据处理 布隆过滤器 位图只能映射整形&#xff0c;而对于字符串却无能为力。 把字符串用哈希算法转成整形&#xff0c;映射一个位置进行标…...

python冒号的用法总结

一维数组 1. 单个冒号的情况 1.1 写完整的情况下 单个冒号的情况下&#xff0c;对数组的遍历操作是从前向后操作。如&#xff1a;arr[a:b] &#xff0c;冒号前的a含义是从a开始遍历&#xff0c;冒号后的b含义是到b截止&#xff08;不包括b&#xff09;。 arr [1, 2, 3, 4,…...

面试题整理

面试题整理 一、Java基础 1、Java 语言有哪些特点 简单易学&#xff1b; 面向对象&#xff08;封装&#xff0c;继承&#xff0c;多态&#xff09;&#xff1b; 平台无关性&#xff08; Java 虚拟机实现平台无关性&#xff09;&#xff1b; 支持多线程&#xff08; C 语言…...

C语言深度解剖-关键字(7)

目录 switch case 语句 理解&#xff1a; 补充&#xff1a; 深入理解&#xff1a; default 语句&#xff1a; case语句&#xff1a; 总结&#xff1a; do、while、for 关键字 while for do while 各种死循环方法&#xff1a; while for do while getchar 写在…...

利用JavaScript编写Python内置函数查询工具

最近我开始学习Python编程语言&#xff0c;我发现Python拥有非常丰富的内置函数&#xff0c;可以用来实现各种不同的功能。但是每当我需要查找一个内置函数时&#xff0c;我总是需要联网使用搜索引擎进行查询。这种方式不仅费时费力&#xff0c;而且需要联网&#xff0c;很不方…...

【MySQL进阶】SQL优化

&#x1f60a;&#x1f60a;作者简介&#x1f60a;&#x1f60a; &#xff1a; 大家好&#xff0c;我是南瓜籽&#xff0c;一个在校大二学生&#xff0c;我将会持续分享Java相关知识。 &#x1f389;&#x1f389;个人主页&#x1f389;&#x1f389; &#xff1a; 南瓜籽的主页…...

最新版海豚调度dolphinscheduler-3.1.3配置windows本地开发环境

0 说明 本文基于最新版海豚调度dolphinscheduler-3.1.3配置windows本地开发环境&#xff0c;并在windows本地进行调试和开发 1 准备 1.1 安装mysql 可以指定为windows本地mysql&#xff0c;也可以指定为其他环境mysql&#xff0c;若指定为其他环境mysql则可跳过此步。 我这…...

csv文件完整操作总结

csv文件完整操作总结 1.概述 csv 模块主要用于处理从电子数据表格Excel或数据库中导入到文本文件的数据&#xff0c;通常简称为 comma-separated value &#xff08;CSV&#xff09;格式因为逗号用于分离每条记录的各个字段。 2.读写操作 2.1.测试数据 创建一个test.csv文…...

时间序列预测--基于CNN的股价预测(Matlab代码实现)

目录 &#x1f4a5;1 概述 &#x1f4da;2 运行结果 &#x1f389;3 参考文献 &#x1f468;‍&#x1f4bb;4 Matlab代码 &#x1f4a5;1 概述 时间序列预测有很多方法&#xff0c;如传统的时序建模方法ARIMA、周期因子法、深度学习网络等&#xff0c;本次实验采用最简单的…...

网站后台运营怎么做/今天的头条新闻

3月25日 周日去练了半天滑翔机&#xff0c;四块电池&#xff0c;慢速飞&#xff0c;重点是做动作和通场。一切顺利。3月26日&#xff0c;单位有事&#xff0c;暂停一天。3月27日&#xff0c;练习一天。上午去了看了看口试题目&#xff0c;回忆了下&#xff0c;想不起来的翻了翻…...

唐山高端网站建设/国内重大新闻10条

author&#xff1a;skate time&#xff1a;2013/03/01 mysql在线无性能影响删除7G大表 如何在mysql数据库里删除7G(或更大)大表&#xff0c;使其又不影响服务器的io&#xff0c;导致性能下降影响业务。先不说其是mysql表&#xff0c;就是普通文件&#xff0c;如果直接rm删除&a…...

mugeda做网站/百度搜索风云榜

实验十 团队作业6-团队项目系统设计改进与详细设计 项目内容这个作业属于哪个课程http://www.cnblogs.com/nwnu-daizh/这个作业的要求在哪里https://www.cnblogs.com/nwnu-daizh/p/10946673.html团队名称坐热板凳组作业学习目标①掌握面向对象软件设计方法&#xff1b;②完善系…...

高碑店网站建设价格/成都网站快速优化排名

很久没有写博客了&#xff0c;最近在学习计算机视觉的相关知识&#xff0c;于是写了一个AR的小Demo。 该程序通过OpenCV实现对Marker的识别和定位&#xff0c;然后通过OpenGL将虚拟物体叠加到摄像头图像下&#xff0c;实现增强现实。首先来看看我们使用的Marker&#xff1a; 这…...

新势力网站建设/网站优化关键词排名

laravel-modules可以通过模块化的方式进行开发。 另外。我们开发可以不从app里面进行开发 因为app本身也携带了一些laravel的类。以后如果出来laravel 9 或者 laravel10的话 我们升级也好升级。因为我们已经新建了别的模块 效果如下 不需要手动 安装。 首先在 Laravel 项…...

时时彩网站开发代理代码/最新注册域名查询

android:divider"drawable/shape"<!--分割线图片-->android:showDividers"middle|beginning|end" <!--分割线位置-->分割线如果是图片那就直接使用图片就行&#xff0c;如果要使用颜色就必须使用shape来显示&#xff0c;直接使用颜色或Color是…...