《考研408数据结构》第六章(5.5树的应用)复习笔记

一、哈夫曼树和哈夫曼编码(最常考)

1、基本概念

2、哈夫曼树构造(重要)

【超级简单】

  • 原理就是每次都选【2个权值最小的节点】,他们相加构成他俩的【父根节点】
    • 然后这两个节点因为依旧构成了一个【最小生成树】,就不再参与计算
  • 下一轮在【剩下的节点】和【刚刚生成的父根节点】里
    • 再找【2个最小节点】构成【最小生成树】

3、哈夫曼编码(简单理解)

意思就是【根节点--->到每个叶节点】的路径数,分别代表一个【字符】

  • 可分为3类:
    • 【固定长度编码】
      • 所有【字符】都用【固定位数的编码】表示
    • 【可变长编码】和【前缀编码】
      • 【可变长编码】:所有【字符】都用【不同位数的编码】表示
        • 但是一旦【某个字符编码】=【另一字符前缀】,那么一连起来就无法区分谁是谁了
      • 【前缀编码】:解决上面的问题,要求没有1个【字符编码】等于【另一字符编码的前缀】表示

那么究其原理,电报里的【哈夫曼编码长度】就等于【树的带权路径长度】,我们想要编码越短越好,那就要构造【哈夫曼树】使得【带权路径长度最短】!!!同时也符合【前缀编码】要求

注意:哈夫曼树形状不唯一,但是【WPL带权路径长度】唯一!!!

二、并查集(还未考察过)

1、用【树和森林】表示【集合】的方式

用的是【树】的【双亲表示法】!!!

2、要干什么?

3、支持的操作

简单看看吧,够清晰了,看不懂也可以不学,反正出的概率不高

相关推荐
ambition202425 分钟前
从暴力搜索到理论最优:一道任务调度问题的完整算法演进历程
c语言·数据结构·c++·算法·贪心算法·深度优先
代码旅人ing17 分钟前
链表算法刷题指南
数据结构·算法·链表
守护安静星空1 小时前
esp32开发笔记-工程搭建
笔记·单片机·嵌入式硬件·物联网·visual studio code
ljt27249606611 小时前
Compose笔记(七十七)--视频录制
笔记·android jetpack
不爱吃炸鸡柳1 小时前
单链表专题(完整代码版)
数据结构·算法·链表
Morwit2 小时前
【力扣hot100】 1. 两数之和
数据结构·c++·算法·leetcode·职场和发展
周周不一样3 小时前
Andorid基础笔记2-jar&反射
笔记·pycharm·jar
智者知已应修善业4 小时前
【51单片机单按键切换广告屏】2023-5-17
c++·经验分享·笔记·算法·51单片机
凉、介5 小时前
别再把 PCIe 的 inbound/outbound、iATU 和 eDMA 混为一谈
linux·笔记·学习·嵌入式·pcie
田梓燊5 小时前
2026/4/11 leetcode 3741
数据结构·算法·leetcode