哈夫曼编码和带权路径计算

哈夫曼树是一种带权路径长度最短的二叉树,也称为最优二叉树。下面用一幅图来说明。

它们的带权路径长度分别为:

图a: WPL=5*2+7*2+2*2+13*2=54

图b: WPL=5*3+2*3+7*2+13*1=48

可见,图b的带权路径长度较小,我们可以证明图b就是哈夫曼树(也称为最优二叉树)。

哈夫曼树构建教程

例:对于给定的一组权值w={1,4,9,16,25,36,49,64,81,100},构造具有最小带权外部路径长度的扩充二叉树,并求出他的的带权外部路径长度。

解:1、首先我们对这一组数字进行排序。规则是从小到大排列(题目已排序好)。

      2、在这些数中 选择两个最小的数字(哈夫曼树是从下往上排列的)写在纸上。如下图所示

  3、用一个类似于树杈的“树枝”连接上两个最小的数。在顶点处计算出这两个数字的和 并写在上面。然后再比较剩下的数字和这个和的大小,再取出两个最小的数字进行排列

4、如上图中30,25的和为55,已经大于36,49.所以这个时候开始有分支,用36,49再构造一个分支,如下图。

5、最后将分支合并成一个二叉树,如下图

6、这样,二叉树结构就构建好了。

 

带权外部路径长度计算;

WPL=2*100 + 3*64 + 2*81 + 4*25 + 2*49 + 2*36 + 5*16 + 6*9 + 7*1 + 7*4 =993

(385的权重为0,216和166权重为1.....)

左0右1:哈夫曼编码为:

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

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

相关文章

codesys raspberry pi_11月7日|Pi第四次减产来袭?4点浅析中文区用户关心的问题

手里有派,心中有爱这两天一些派友私下找我在抱怨,也有用户在我们的微信社群发出所谓的灵魂询问:“主网在哪里??制宪大会在哪里?停产或者减产在哪里?kyc在哪里?”我简单的回应一下&am…

android微信h5转原生支付,微信原生支付流程以及踩坑

本次记录的是微信“JSAPI”的支付方式 也就是微信内H5页面调起支付,其他支付方式也大同小异,总体的流程和思路大致是一样的,基本配置方面就不详细记录,只需要商户号和商户Key,这个是配套的,还有跟商户号绑…

python编程学习做什么-什么样的人要学点python编程?请你对号入座

什么样的人需要学点python编程? 时代越来越不一样了,编程这种专业程序员的工作,已经开始应用于各种其他日常工作中,就以前象征着互联网的电脑,现在早已进入普通人家。 那么什么样的人需要学点python编程呢?…

android 网页取词,有道词典屏幕取词怎么用?,你知道吗?在浏览网页

有道词典屏幕取词怎么用?,你知道吗?在浏览网页你知道吗?在浏览网页时遇到不懂的外文、词语等,我们可以通过有道词典的屏幕取词来进行翻译哦!好吧,你肯定会问:我如何使用这一功能呢?下…

你发这些什么目的_微信CRM系统究竟是什么?

作为一个电商运营人,近期行业内经常会听到一个名词,微信CRM系统,私域流量,用微信CRM系统打造属于自己的私域流量。相信很多做电商的也是和我一样,对于这个词很耳熟,但是又不知道是什么意思,因此…

C++ 输入有空格一行的接收

#include<iostream> #include<string> using namespace std; int main() {char input_str[100]; //输入有空格的一行。cin默认以空格结束cin.getline(input_str, 100);int num_num 0;int num_letter 0;int num_space 0;int num_other 0;int len strlen(input…

android微信支付坑,微信支付踏坑之旅

其实微信支付的集成步骤也就那么几步&#xff0c;奈何第一次接触无论是微信官方文档还是5SDK文档都看的晕头转向&#xff0c;于是我换个思路(以下只针对android app支付功能&#xff0c;服务端为java)1、首选确定app已经开通支付功能&#xff0c;确保 包名、应用签名、appid、m…

通过conda安装imgaug

直接采用pip install imgaug 错误 需要先安装sharply包 输入命令&#xff1a; conda install -c conda-forge shapely 然后输入命令&#xff1a; pip install imgaug 或者&#xff08;当上面安装命令出现超时等错误时&#xff09; pip install imgaug -i https://pypi.t…

多个服务器数据互通_5月23日部分服务器数据互通公告!

为了提升游戏品质&#xff0c;给各位仙友创造更好的游戏环境&#xff0c;我们将于5月23日6:00对部分服务器进行“数据互通”操作&#xff0c;开服待定。参与合服的服务器可参与合服活动&#xff0c;详细请合服后登录游戏查看。服务器“数据互通”后&#xff0c;原登录界面上的服…

conda安装tensorflow-gpu

1、安装Anaconda Anaconda下载地址&#xff1a;https://www.anaconda.com/download/ 选择合适的版本&#xff0c;进行下载安装即可。 下载完成后就双击安装就可以了 一步一步按照默认的来就可以了&#xff0c;注意一下&#xff0c;注意勾选添加到环境变量&#xff0c;不然后面…

ipv6的127位掩码如何表示_子网掩码为255.255.255.0代表的意思是什么?

展开全部子网掩码为代表的copy意思是代表有2113254个可用IP。总IP数为16&#xff0c;包括一个5261网络地址&#xff0c;一个广播4102地址和1653254个可用地址。子网掩码是一个32位地址&#xff0c;用于屏蔽IP地址的一部分以区别网络标识和主机标识&#xff0c;并说明该IP地址是…

android蓝牙设置名称流程,Android 8 设置蓝牙名称 流程

记录android 8设置蓝牙名称的流程。javapackages/apps/Settings/src/com/android/settings/bluetooth/BluetoothDeviceRenamePreferenceController.java显示更改框Overridepublic boolean handlePreferenceTreeClick(Preference preference) {if (PREF_KEY.equals(preference.g…

github下载

第一种方案&#xff1a;修改host&#xff08;几乎属于无效方案&#xff09; 1、获取GitHub的官方CDN地址 打开https://www.ipaddress.com/查询以下三个链接的DNS地址解析github.comassets-cdn.github.comgithub.global.ssl.fastly.net 记录下查询到的IP地址。 2、修改系…

rt-thread怎么使用数码管_三菱FX PLC功能指令,怎么学?

很多小伙伴问学完编程入门后又应该学习什么内容呢&#xff1f;我的回答是&#xff0c;学完三菱编程入门后应该学习三菱FX PLC功能指令&#xff0c;包括功能指令的预备知识、三菱FX系列PLC的编程元件、寻址方式等&#xff0c;以及三菱FX PLC的所有功能指令的使用和应用。注意&am…

html界面等待状态,html 等待界面

发送中,请稍等...function show(o1,o2,open){var o1 document.getElementById(o1);var o2 document.getElementById(o2);o1.style.width document.documentElement.scrollWidth;o1.style.height document.documentElement.scrollHeightif(open){o1.style.display "bl…

信息学奥赛之数学一本通_部分地区中考加分,又一批中学公布中考认可信息学特长生!...

点击上面微信号关注我关注我哟定期推送帐号信息学新闻&#xff0c;竞赛自主招生&#xff0c;信息学专业知识&#xff0c;信息学疑难解答&#xff0c;信息学训练营信息等诸多优质内容的微信平台&#xff0c;欢迎分享文章给你的朋友或者朋友圈&#xff01;有任何问题请联系小编&a…

ios 获取html中的json数据,[IOS]UIWebView实现保存页面和读取服务器端json数据

#import"ViewController.h"interfaceViewController()endimplementation ViewController- (void)viewDidLoad{[superviewDidLoad];// Do any additional setup after loading the view, typically from a nib.//请求网络页面// NSURL * url [NSURL URLWithString…

解决cv2.error: OpenCV(4.0.0)的方法

首先检查图片路径 其次可能就是 新版本的兼容性问题 把OpenCV 4. 0.0 换成 3. 4的就好了 pip install -U opencv-python3.4.4.19 参考自https://blog.csdn.net/weixin_41279876/article/details/88682534

电脑打开微信小程序_终于可以在电脑上玩转微信小程序啦

微信小程序可以在电脑PC端打开吗&#xff1f;这是很久之前都有朋友问的一个问题了&#xff0c;今天可以告诉大家这个好消息&#xff0c;微信PC端2.7.0.65测试版已经增加这一功能了。目前该功能支持windows 7及以上版本操作系统&#xff0c;Mac还未开放&#xff0c;应该不会等太…

html九宫格抽奖视频,原生JS实现九宫格抽奖效果

效果图&#xff1a;代码如下&#xff1a;*{margin:0;padding:0;}#container{width:310px;height:310px;margin:30px auto;}#ul1{width:310px;height:310px;list-style:none;}#ul1 li,#ul1 a{width:100px;height:100px;border:1px solid #565656;float:left;text-align:center;l…