【树与二叉树的转换,哈夫曼树的基本概念】

文章目录

  • 树与二叉树的转换
  • 将二叉树转化为树
  • 森林与二叉树的转化(二叉树与多棵树之间的关系)
  • 二叉树转换为森林
  • 森林的先序遍历
    • 1)先序遍历
    • 2)后序遍历
  • 哈夫曼树的基本概念
  • 森林转换成二叉树(二叉树与多棵树的关系)

树与二叉树的转换

将树转化为二叉树处理,利用二叉树的算法实现对树的操作。
由于树和二叉树都可以用二叉树链表做存储结构,则二叉链表的媒介可以导出与二叉树之间的对应关系。
给定一棵树,可以找到唯一的一棵二叉树与之对应。
在这里插入图片描述
在这里插入图片描述
树变二叉树:兄弟相连留长子。
例如:
①兄弟相连

在这里插入图片描述
②留长子
在这里插入图片描述
在这里插入图片描述

将二叉树转化为树

左孩右右连双亲,去掉原来右孩线。
在这里插入图片描述
在这里插入图片描述

森林与二叉树的转化(二叉树与多棵树之间的关系)

树变二叉根相连
①将各棵树分别转换为二叉树。
②将每棵树的根结点用线相连。
③以第一棵树根结点为二叉树的根,再以根结点为轴心,顺时针旋转,构成二叉树结构。
在这里插入图片描述

二叉树转换为森林

去掉全部右孩线,孤立二叉再还原。
在这里插入图片描述

森林的先序遍历

1)先序遍历

  • 若森林不空,则先访问根结点,然后从左向右的顺序,先遍历根结点的每一棵子树(依次从左至右对森林中的每一棵树进行先根遍历)。
  • 树的先根遍历书序应该和二叉树的先序遍历顺序相同。

2)后序遍历

  • 如果树非空,则按从左往右的顺序,后根遍历根结点的每一棵子树,然后访问根结点。
  • 树的后根遍历顺序应与该树对应二叉树遍历顺序相同。

哈夫曼树的基本概念

  • 路径:从树中的一个结点到另一个结点之间的分支构成这两个结点间的路径。
  • 结点的路径长度:两结点路径上的分支数。
    例如:
    在这里插入图片描述这里表示的是从A结点到H结点的路径,路径长度为4。
  • 树的路径长度:从树根到每一个结点的路径长度之和。记作TL。
    例如:
    在这里插入图片描述
    结点数目相同的二叉树中,完全二叉树的路径长度最短的二叉树。

森林转换成二叉树(二叉树与多棵树的关系)

①将各棵树分别转换为二叉树。

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

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

相关文章

修改Conda虚拟环境默认位置失败——解决方案

修改虚拟环境默认安装位置依然❌ 偶然遇到conda创建虚拟环境创建失败的问题,按照教程修改.condarc文件中 envs_dirs:- E:\miniconda3\envs依然无法更改虚拟环境默认安装位置。 解决方案 找到想更改的虚拟环境文件位置,检查确认是否有写入权限&#…

在Python中使用sqlite3进行数据持久化操作

目录 引言 一、安装sqlite3模块 二、创建数据库连接 三、创建游标对象 四、执行SQL命令 五、提交更改 六、关闭连接 七、使用参数化查询 八、使用ORM进行数据操作 九、备份和恢复数据库 十、处理大量数据 十一、优化查询性能 十二、处理并发访问 十三、处理数据持…

小波神经网络的时间序列预测——短时交通流量预测

大家好,我是带我去滑雪! 小波神经网络(Wavelet Neural Network,WNN)结合了小波变换和神经网络的特性,是一种在信号处理和模式识别领域应用广泛的神经网络模型。它的设计灵感来自于小波变换的多尺度分析特性…

JSP注释方式演示 讲解显式与隐式注释

好 今天我们来了解一下jsp中的注释哦 它支持两种注释: 显式注释/隐式注释 显式注释 是 允许被客户端看到的 就是 打开浏览器 用查看源码方式能看到的注释 与之对应 隐式注释 就是 在客户端 是无法看到这些注释信息的 显式注释 的语法就是html的注释语法 <!-- 显式注释 --…

AdaBoost:提升机器学习的力量

一、介绍 机器学习已成为现代技术的基石&#xff0c;为从推荐系统到自动驾驶汽车的一切提供动力。在众多机器学习算法中&#xff0c;AdaBoost&#xff08;Adaptive Boosting的缩写&#xff09;作为一种强大的集成方法脱颖而出&#xff0c;为该领域的成功做出了重大贡献。AdaBoo…

node将package.json中的包降为低版本或者升级为高版本

前言 比如现在你用某个包的当前版本&#xff0c;但是你安装的版本高了&#xff0c;那么你应该这么做 1.首先删除node项目中的node_modules目录&#xff0c;防止安装时的包不一致 如果没安装就忽略 例如将package.json中的view-design包降为^4.6.1,当前view-design的版本为^4.…

解决LX音乐切换音乐来源失败问题

之前免费听歌神器落雪音乐不能用了&#xff0c;原因懂得都懂 LX音乐Github链接 可以通过切换音乐来源进行解决 一、下载自定义音源文件 免费下载链接 下载一 百度网盘&#xff1a;1o7v 下载二 CSDN资源&#xff1a;自定义音源 全部音源文件来源 蓝奏云&#xff1a;8mno 下…

QT QDockWidget

QDockWidget是Qt中的一个容器类&#xff0c;用于在主窗口上创建可停靠的子窗口。 设置停靠窗口的一般流程如下: (1)创建一个QDockWidget 对象的停靠窗体。 (2)设置此停靠窗体的属性&#xff0c;通常调用setFeatures()及setAllowedAreas()两种方法。 (3)新建一个要插入停靠窗…

CentOS修改root用户密码

一、适用场景 1、太久没有登录CentOS系统&#xff0c;忘记管理密码。 2、曾经备份的虚拟化OVA或OVF模板&#xff0c;使用模板部署新系统后&#xff0c;忘记root密码。 3、被恶意攻击修改root密码后的紧急修复。 二、实验环境 1、VMware虚拟化的ESXI6.7下&#xff0c;通过曾经…

探索SOLIDWORKS 3DE云平台:产品数据管理与协作的新时代

SOLIDWORKS 3DE云平台为企业提供了基于云端的全方位解决方案&#xff0c;涵盖了产品设计、仿真验证、制造与生产、市场与营销、数据管理和生命周期等领域。通过这一平台&#xff0c;企业能够将创意转化为现实所需的一切资源。同时&#xff0c;3DE云平台还帮助企业摆脱了IT限制&…

图数据库Neo4j详解

文章目录 第一章 图和Neo4j1.1 图数据库概念1.1.1 图论起源1.1.2 节点-关系及图1.1.3 图数据库1.1.4 图数据库分类1.1.4 图数据库应用场景1.1.5 与关系型数据库对比1.1.6 图数据库优势 1.2 Neo4j介绍1.2.1 Neo4j是什么1.2.2 Neo4j特点1.2.3 Neo4j的优势1.2.4 Neo4j的限制1.2.5 …

【python】单词接龙

题目&#xff1a; 这是一个关于“单词接龙”的算法题目。在这个游戏中&#xff0c;我们需要从给定的一组单词中&#xff0c;以特定的开头字母构造出一条最长的“龙”。每个单词在这条“龙”中最多出现两次。当两个单词相连时&#xff0c;它们的重合部分被合并成一个。例如&…