哈夫曼树学习笔记
1|0定义:
- 1.二叉哈夫曼树:对于一个数列,构建一棵树上带权路径之和最小的二叉树(当然可以
叉) - 2.树上带权路径:每个叶子节点到根节点的路径上所有节点的点权
和到跟的路径长度 的乘积之和
简单来说,哈夫曼树满足 最小
2|0基本构造方法:
前置知识(没做过也可以,但至少要会优先队列):合并果子
一点没错,就是合并果子。你考虑这么一件事,我们想要的就是权值越大的店越靠近根节点,这样
具体的步骤如下:
- 1.将
个元素创建 个节点并视为 棵树,权值 即为元素 - 2.选择权值最小的两个根节点
,创建一个虚拟节点,并将左右子树设为 ,权值为 (相当于把这两棵树合并了) - 3.重复步骤2直到成为一棵树
拿一个序列过来演示一下:
3|0哈夫曼编码:
哈夫曼树通常和哈夫曼编码一起使用,什么是哈夫曼编码呢?
我们截取小明一天给他同学发的短信:
- 1.我今天又爆零了
- 2.我中午吃的面
- 3.今天考试爆零的好多
这些消息在二进制下就是一堆 串,而且在正常编码的情况下每个汉字占的字节都一样多。我们知道传输信息要消耗能量,那么能不能让传输的字符串短一点呢。
一种思路是:让使用更为频繁的汉字编码尽可能的短,比如上文的三句话中,“我”这个字出现次数多,编成
可还有一个问题,假设“我”是
怎么解决这个问题呢?我们观察上面构造的哈夫曼树,发现每个原节点都是叶子节点,这是显然的,那么就不可能出现一个节点的编码是另一个的前缀。我们只需要把每个字的使用次数当作权值建立哈夫曼树,从根节点开始,向左在字符串后加一位
4|0例题:
4|11.HDU - 1053 Entropy
链接
第一个答案是正常编码的长度,众所周知一个字符长度为
第二个答案是哈弗曼编码的长度,你不用真的建树(建了当然也可以),直接用合并果子就行。但要特判只有一种字符的情况(根本不合并)
第三个答案是前两个的比值
4|2CODE:
4|32.P2168 [NOI2015] 荷马史诗
链接
一眼哈夫曼树,可是是
其他都没有区别,第一问就是最大深度减一。值得注意的是因为最后一次合并不一定有
显然
于是我们一开始不停插入权值为
你可能会问怎么知道插入几个
4|4CODE:
__EOF__

本文链接:https://www.cnblogs.com/wangwenhan/p/17654467.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!