Huffman编解码问题——讲解.docx

  1. 1、本文档共8页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Huffman编解码问题——讲解

2.5 Huffman编码问题实验四——题目2:利用二叉树结构实现哈夫曼编/解码器。基本要求:1、初始化(lnit):能够对输入的任意长度的字符串s进行统计,统计每个字符的频度, 并建立哈夫曼树2、建立编码表(CreateTable):利用己经建好的哈夫曼树进行编码,并将每个字符的 编码输出。3、编码(Encoding):根据编码表对输入的字符串进行编码,并将编码后的字符串输出。4、译码(Decoding):利用己经建好的哈夫曼树对编码后的字符串进行译码,并输出 译码结果。5、打印(Print):以直观的方式打印哈夫曼树(选作)6、计算输入的字符串编码前和编码后的长度,并进行分析,讨论赫夫曼编码的压 缩效果。7、可采用二进制编码方式(选作)实验讲解:Huffman编解码的实验按照模块化分,可以划分成如下部分:统计输入的字符串中字符频率创建Huffman树打印Huffman树创建Huffman编码表对输入的字符串进行编码并输出编码结果对编码结果进行解码,并输出解码后的字符串最后编写测试函数,测试上述步骤的正确性。根据模块化分,设计Huffman的存储结构如下:1) Huffman树的结点结构 structHNode {intweight;//结点权值intparent;//双亲指针intLChild;//左孩子指针intRChild ;//右孩子指针};20datacode0Z1001C1012B113A052)编码表结点结构(如右图2-6所示)11structHCode {chardata; charcode[100];};图2-6 Huffman树编码结构3) Huffman类结构classHuffmanprivate:HNode* HTree; HCode* HCodeTable; charstr[1024]; charleaf[256]; inta[256]; public://Huffman树 //Huffman编码表//输入的原始字符串 //叶子节点对应的字符 //记录每个出现字符的个数{intn;//叶子节点数voidinit();//初始化voidCreateHTree();//创建 huffman树voidSelectMin(int x, int y, ints, inte);voidCreateCodeTable();//创建编码表voidEncode(char *d);//编码voidDecode(char *s, char *d);//解码voidprint(inti, intm);//打印 Huffman树?Huffman();}根据实验要求,分步骤实现如下:步骤1:统计输入的字符串中字符频率Huffman编码的第一步需要使用字符出现的频率作为输入,本实验使用从键盘输入的方 式进行,需要的解决得问题有2个:一是输入的字符串中间有空格如何处理?二是如何使统 计效率更高?例如:char str[1024]; cinstr;上述代码运行后输入字符串,但cmstr遇到空格就停止本次读取,所以我们需要使用 其它的方法来进行输入,即需要使用cm.get()函数进行字符串读取。get()方法每调用一次, 读取一个字符,该字符的ASCII码作为返回值返回,换行回车等控制字符也当作普通字符进行读取,因此需要指定结束读取的标志字符,才能停止get()函数的循环调用。 本实验中可以将字符读取和统计结合在一起进行。示例代码如下://记录每一个字符出现的次数//统计字符出现的次数 //记录原始字符串 //读取下一个字符intnNum[256]= {0};intch= cin.get();inti=0;while((ch!=V) (ch!=’\n’)) {nNum[ch]++;str[i++] = ch;ch = cin.get();}str[i]=,\0’其中,整型数组变量nNum用来记录每一个字符出现的次数(若该字符未出现,则对应 的nNum[ch]的值为0),可以把读取的字符ch的ASCII码当成,当ch出现时,nNum[ch]自动加一。当然,数组nNum中的等于零的字符会有很多,不方便后续hufman树的创建,因此可以进行过滤,仅留下出现次数大于零的字符。因此,完整的初始化代码如下: voidHuffman::init(){①?⑧n= 0;for ( i=0;i256;i++){if (nNum[i]0)//若nNum[i]==0说明该字符未出现{leaf[n] = (char)i; a[n] = nNum[i];n++;}}}其中,数组leaf存储出现次数大于零的字符,相应的数组a存储该字符出现的次数,n 为字符数,作为步骤2创建Huffman树的输入。字符数组str存储用户输入的字符串,作为 步骤5编码的输入。当然,

文档评论(0)

bigone123 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档