【开卷数据结构 】哈夫曼编码

简介: 【开卷数据结构 】哈夫曼编码

05d250eb22e3badf2cfb05fc5f2f91af_94536690f848438fab30aa17191a6ea2.png

🌺哈夫曼编码


如果有一段文字【ABCDEF】要网络传输给别人,在进行数据压缩时,最简单的编码方法就是固定长度编码。


🍁固定长度编码


Q:什么是固定长度编码


A:在数据通信中,若对每个字符用相同的二进制位表示,称这种编码方式为固定长度编码。


有一段文字【BADCADFEED 】,我们可以用相应的二进制的数据表示,如图所示

字母 A B C D E F
二进制字符 000 001 010 011 100 101

这样真正传输的数据就是编码后的 【001000011010000011101100100011】 (三十个字符),对方接收时可以按照3位一分来译码。如果一篇文章很长,这样的二进制串也将长的非常的可怕,那么有没有什么方法可以对其进行压缩的吗?


🍁哈夫曼编码


我们假设各字母出现的频率如下


假设六个字母的频率为 A:27  B:8  C:15  D:15  E:30  F:5 ,合起来正好是 100 ,那就意味着,我们完全可以重新按照赫夫曼树来规划它们。


897cc05e75ca56398a1bb89b581d6262_b2e1e9c5247b4d27ba389b0cd27d810c.png


我们将左分支权值改为0,右分支权值改为1,那么该哈夫曼树就变成了


f1d74ce3388fea5d574b2fca48bd73c6_5ea7b76628f94e53a6c0b19d70e2d1f0.png


这时,我们对着六个字母用其从树根到叶所经过路径的 0 与 1 来编码,按照新的字母对应的二进制字符对【BADCADFEED 】进行编码,通过对比可以很明显的发现,字符数量减少了。


固定长度编码:001000011010000011101100100011(共30个字符)

哈夫曼编码:    1001010010101001000111100         (共25个字符)

哈夫曼编码的特点:


对频率高的字符赋以短编码。

对频率较低的字符则赋予较长一些的代码。

从而使得字符的平均编码长度减短,起到压缩数据的效果。

哈夫曼编码是一种被广泛应用而且非常有效的数据压缩编码。


🍁前缀编码


Q:什么是前缀编码


A:前缀编码是指对字符集进行编码时,要求字符集中任一字符的编码都不是其它字符的编码的前缀。


仔细观察,哈夫曼编码其实就是一种前缀编码


Q:前缀编码有什么优点


A:通过观察前缀编码(哈夫曼编码)【1001010010101001000111100】,以及其对应的哈夫曼树,我们发现不会出现容易混淆的编码,比如不会出现与1000,1001混淆的10,100编码。


f1d74ce3388fea5d574b2fca48bd73c6_5ea7b76628f94e53a6c0b19d70e2d1f0.png


对前缀编码的解析很简单,因为没有一个编码是其他编码的前缀。所以识别出第一个编码,将它翻译成原码,再对余下的编码文件重复同样的解码操作即可。例如,码串 00101100 可被唯一的翻译成 0,0,101,100 .


🌺文件的编码与译码


🍁编码


有了字符集的哈夫曼编码表之后,对数据文件的编码过程是:依次读人文件中的字符c,在哈夫曼编码表HC中找到此字符,将字符c转换为编码表中存放的编码串。


🍁译码


对编码后的文件进行译码的过程必须借助于哈夫曼树。具体过程是:依次读入文件的二码,从哈夫曼树的根结点(即HT[m])出发,若当前读入0,则走向左孩子,否则走向右孩子。一旦到达某一叶子HT[i]时便译出相应的字符编码HT[i]。然后重新从根出发继续译码,直至文件结束。


相关文章
|
存储 算法 C语言
C语言---数据结构实验---哈夫曼树及哈夫曼编码的算法实现---图的基本操作
C语言---数据结构实验---哈夫曼树及哈夫曼编码的算法实现---图的基本操作
|
4月前
|
存储 C语言
数据结构基础详解(C语言): 树与二叉树的应用_哈夫曼树与哈夫曼曼编码_并查集_二叉排序树_平衡二叉树
本文详细介绍了树与二叉树的应用,涵盖哈夫曼树与哈夫曼编码、并查集以及二叉排序树等内容。首先讲解了哈夫曼树的构造方法及其在数据压缩中的应用;接着介绍了并查集的基本概念、存储结构及优化方法;随后探讨了二叉排序树的定义、查找、插入和删除操作;最后阐述了平衡二叉树的概念及其在保证树平衡状态下的插入和删除操作。通过本文,读者可以全面了解树与二叉树在实际问题中的应用技巧和优化策略。
|
7月前
|
机器学习/深度学习 存储
数据结构学习记录——哈夫曼树(什么是哈夫曼树、哈夫曼树的定义、哈夫曼树的构造、哈夫曼树的特点、哈夫曼编码)
数据结构学习记录——哈夫曼树(什么是哈夫曼树、哈夫曼树的定义、哈夫曼树的构造、哈夫曼树的特点、哈夫曼编码)
250 1
|
8月前
|
存储 NoSQL 程序员
Redis -- 常用数据结构,认识数据类型和编码方式
Redis -- 常用数据结构,认识数据类型和编码方式
55 2
|
8月前
|
存储 NoSQL 算法
Redis源码、面试指南(2)内存编码数据结构(下)
Redis源码、面试指南(2)内存编码数据结构
71 4
|
8月前
|
存储 NoSQL API
Redis源码、面试指南(2)内存编码数据结构(上)
Redis源码、面试指南(2)内存编码数据结构
80 0
|
8月前
|
Java API
编码的奇迹:Java 21引入有序集合,数据结构再进化
编码的奇迹:Java 21引入有序集合,数据结构再进化
71 0
|
存储 缓存 NoSQL
头条高级面试题:请谈谈Redis 9种数据结构以及它们的内部编码实现
0%的人知道Redis 5种最基本的数据结构,只有不到10%的人知道8种基本数据结构(5种基本+bitmap+GeoHash+HyperLogLog),只有不到5%的人知道9种基本数据结构(5.0最新版本数据结构Streams),只有不到1%的人掌握了所有9种基本数据结构以及8种内部编码,掌握这篇文章的知识点,让你成为面试官眼中Redis方面最靓的仔! 说明:本文基于Redis-3.2.11版本源码进行分析。
86 0
|
存储 算法
数据结构实验十二 哈夫曼树及编码
数据结构实验十二 哈夫曼树及编码
108 0