用C++实现数据无损压缩、解压(使用LZW算法.doc

用C++实现数据无损压缩、解压(使用LZW算法.doc

ID:56356188

大小:286.50 KB

页数:11页

时间:2020-06-22

用C++实现数据无损压缩、解压(使用LZW算法.doc_第1页
用C++实现数据无损压缩、解压(使用LZW算法.doc_第2页
用C++实现数据无损压缩、解压(使用LZW算法.doc_第3页
用C++实现数据无损压缩、解压(使用LZW算法.doc_第4页
用C++实现数据无损压缩、解压(使用LZW算法.doc_第5页
资源描述:

《用C++实现数据无损压缩、解压(使用LZW算法.doc》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、用C++实现数据无损压缩、解压(使用LZW算法)LZW压缩算法由Lemple-Ziv-Welch三人共同创造,用他们的名字命名。LZW就是通过建立一个字符串表,用较短的代码来表示较长的字符串来实现压缩。LZW压缩算法是Unisys的专利,有效期到2003年,所以对它的使用是有限制的。字符串和编码的对应关系是在压缩过程中动态生成的,并且隐含在压缩数据中,解压的时候根据表来进行恢复,算是一种无损压缩。个人认为LZW很适用于嵌入式系统上。因为:1、压缩和解压速度比较快,尤其是解压速度;2、占用资源少;3、压缩比也比较理想;4、适用于

2、文本和图像等出现连续重复字节串的数据流。LZW算法有一点比较特别,就是压缩过程中产生的字符串对应表,不需要保存到压缩数据中,因为这个表在解压过程中能自动生成回来。LZW算法比较简单,我是按照这本书上写的算法来编程的:10227717016.jpg(124.6KB)2009-1-511:5710227717017.jpg(123.14KB)2009-1-511:57以下是源代码:复制内容到剪贴板代码:classLZWCoder{private:      structTStr      {          char*strin

3、g;          unsignedintlen;      };      TStrStrTable[4097];      unsignedintItemPt;      unsignedintBytePt;      unsignedcharBitPt;      unsignedcharBit[8];      unsignedcharBits;      unsignedintOutBytes;      voidInitStrTable();      voidCopyStr(TStr*d,TStrs);   

4、   voidStrJoinChar(TStr*s,charc);      unsignedintInStrTable(TStrs);      voidAddTableEntry(TStrs);      voidWriteCode(char*dest,unsignedintb);      unsignedintGetNextCode(char*src);      voidStrFromCode(TStr*s,unsignedintc);      voidWriteString(char*dest,TStrs);pu

5、blic:      unsignedintEncode(char*src,unsignedintlen,char*dest);      unsignedintDecode(char*src,unsignedint*len,char*dest);      LZWCoder();      ~LZWCoder();};voidLZWCoder::InitStrTable(){      unsignedinti;      for(i=0;i<256;i++)      {          StrTable[i].stri

6、ng=(char*)realloc(StrTable[i].string,1);          StrTable[i].string[0]=i;          StrTable[i].len=1;      }      StrTable[256].string=NULL;      StrTable[256].len=0;      StrTable[257].string=NULL;      StrTable[257].len=0;      ItemPt=257;      Bits=9;}voidLZWCod

7、er::CopyStr(TStr*d,TStrs){      unsignedinti;      d->string=(char*)realloc(d->string,s.len);      for(i=0;istring[i]=s.string[i];      d->len=s.len;}voidLZWCoder::StrJoinChar(TStr*s,charc){      s->string=(char*)realloc(s->string,s->len+1); 

8、     s->string[s->len++]=c;}unsignedintLZWCoder::InStrTable(TStrs){      unsignedinti,j;      boolb;      for(i=0;i<=ItemPt;i++)      {   

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。