Skip to content

练习用,使用C++实现的LZW压缩算法,以及对中文文本压缩的改进,改进方案参考陈庆辉的中文文本压缩的LZW算法一文

Notifications You must be signed in to change notification settings

vic233/LZW-Compress-Algorithm

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

12 Commits
 
 
 
 
 
 

Repository files navigation

LZW算法及其改进

练习用,可直接对文件操作,使用C++实现的LZW压缩算法,实现对文本的压缩,以及对中文文本压缩的改进,改进方案参考陈庆辉的中文文本压缩的LZW算法一文。

介绍

  • LZW_Compress.cpp为纯原生的LZW压缩算法,完全按照LZW算法的流程实现,没有任何关于词典重构等方面的优化。主要适用于英文等单字节文本,词典初始化为所有ASCII码,码字最大为32位(4B)。

输出示例

控制台输入

image

文件输入

image

  • LZWCH_Compress.cpp为在上一份代码的基础上对中文文本压缩的优化实现,可以对GB2312编码、GBK编码、ASCII编码混合文本实现压缩与解压,词典基本码集为常用GB2312编码,并在基本码集中预留自定义数量的空条目,因此,其对GB2312编码的压缩率最好,对GBK次之。不支持utf-8与Unicode编码。存储在词典中的条目内容为码值+编码的二进制字符串,且字符串中有分割符,因此占用存储空间较大。

输出示例

控制台输入

控制台输入_压缩

文件输入

三国演义_压缩

About

练习用,使用C++实现的LZW压缩算法,以及对中文文本压缩的改进,改进方案参考陈庆辉的中文文本压缩的LZW算法一文

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages