基于字典的LZW压缩算法
创始人
2024-03-14 23:05:07
0

基于字典的LZW压缩算法

  • 基于字典的LZW压缩算法
    • 简介
    • 重要概念:前缀和后缀
    • 算法
    • 示例

基于字典的LZW压缩算法

简介

J.Ziv和A.Lempel在1978年首次发表了介绍第二类词典编码算法的文章。在他们的研究基础上,Terry A.Wlch在1984年发表了改进这种编码算法的文章。因此把这种编码方法称为LZW压缩算法。

LZW算法又叫“串表压缩算法”就是通过建立一个字符串表,用较短的代码来表示较长的字符串来实现压缩。 LZW压缩算法是Unisys的专利,有效期到2003年,所以对它的使用已经没有限制了。

重要概念:前缀和后缀

两个重要概念:

  • 前缀(prefix):一个词组的前面一个字符 ,比如 ab,前缀为a,8f前缀为8;

  • 后缀(suffix):反之,为后一个字符,比如 ab,后缀为b,8f后缀为f;

算法

算法流程:

  1. 在输入流中读一个字符。
  2. 如果当前编码在字典中,则把当前编码的第一个字符作为当前串的后缀,如果当前串不在字典中,就把它加入到字典中,然后把当前编码作为串的前缀,转到第4步。
  3. 如果当前编码不在字典中,就把前缀的第一个字符作为后缀,把串加入到字典中,用当前串的编码作前缀,转到第4步。
  4. 把前缀放到输出流,转到第1步。

示例

对于字符串ababbacb。初始字典为{a, b, c}。

步骤前缀后缀存在对应码输出
1a(, a)
2ab(a, b)noa256
3ba(b, a)nob257
4ab(a, b)yes
5256b(256, b)no256258
6ba(b, a)yes
7257c(257, c)no257259
8cb(c, b)noc260

把输出来的和最后一个后缀连在一起则是:a,b,256,257,c,b这6个字符,那么就达到了压缩的目的。

对应生成的码表则是:

256257258259260
(a, b)(b, a)(256, b)(257, c)(c, b)

解压缩时,将输出字符串按照码表对应转化。a,b,256(ab),257(ba),c,b,即ababbacb,解压成功。

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...