将Huffman编码规则存储到压缩文件

1.

1.1 原理

以 [字符1的原编码 + 字符1的Huffman编码 + 字符1的Huffman编码长度, 字符2的原编码 + 字符2的Huffman编码 + 字符2的Huffman编码长度, …]的方式暴力存储。

这个方法需要注意的是所有字符的原编码都需占据相同的二进制位数, 比如16bit。 所有字符的Huffman编码也必须占据相同的二进制位数,比如16bit. 编码长度也是一样。

因为huffman码是不定长码,所以需要在后缀补0对齐。

1.2 举例

假设有三个字符 [A, B, C] 。 它们的原二进制编码分别为0x41, 0x42, 0x43; 霍夫曼编码分别是00, 01, 1。我们规定原编码 , huffman编码, 长度分别占据一个字节也就是8bit。
那么编码如下(16进制):

41 00 02
42 40 02
43 80 01

我们以第二行为例。
第一个字节是ASCII码,0x42 = 66, 代表’B’.
然后通过我们看看第三个代表长度的字节0x02,也就是说真正的huffman码只有两个bit。
那么只取0x40的前两个bit,也就是01.

1.3 Unicode

如果字符集包含汉字,得用Unicode,比如utf-16.

utf-16是不定长码,处理方法有两种,一是补0对齐;二是以一个字节为单位进行huffman编码。

2.

通过规范霍夫曼编码,无需保存huffman编码,相比于1更节省空间。

发现了一篇好的blog,懒得自己写了。 范式哈夫曼编码

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值