哈夫曼编码详解

哈夫曼编码

根据数据使用的频率来生成对应的哈夫曼树

生成法则则是:把数据使用的频率当做权重,先将两个权重最低的相加。再在剩余的权重里面,再找出使用频率最低的两个,以此类推。

权重小的放在左边,大的在右边。直到遍历完全部的数据,哈夫曼树就生成了。

而哈夫曼编码,则是从根节点开始,左节点标记为0,右节点标记为1.

例:

**a,b,c,d,e 对应出现的频率为4,6,11,13,15,则a,b,c,e,d的哈夫曼编码是?

先把出现频率当成权重,选出权重最低了两个相加。
a和b相加,4+6=10

在这里插入图片描述

剩余 10,11,13,15 重复步骤一,10+11=21

在这里插入图片描述

剩余 21.13,15 这是最低的两个变成了13和15相加为28

在这里插入图片描述

最后将21与28相加得到根节点,一颗哈夫曼树就生成了。

在这里插入图片描述

而要得到哈夫曼编码只需要按左0右1的原则给所有分支编码就可以了

在这里插入图片描述

就得到了abcde的哈夫曼编码

a:000 b:001 c:01 d:10 e:11

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值