哈夫曼编码译码的设计实现分析

上传人:M****1 文档编号:488252777 上传时间:2022-07-30 格式:DOC 页数:33 大小:66KB
返回 下载 相关 举报
哈夫曼编码译码的设计实现分析_第1页
第1页 / 共33页
哈夫曼编码译码的设计实现分析_第2页
第2页 / 共33页
哈夫曼编码译码的设计实现分析_第3页
第3页 / 共33页
哈夫曼编码译码的设计实现分析_第4页
第4页 / 共33页
哈夫曼编码译码的设计实现分析_第5页
第5页 / 共33页
点击查看更多>>
资源描述

《哈夫曼编码译码的设计实现分析》由会员分享,可在线阅读,更多相关《哈夫曼编码译码的设计实现分析(33页珍藏版)》请在金锄头文库上搜索。

1、-软件学院课程设计报告设计名称: 数据构造课程设计 选题名称: 哈夫曼编码/译码的设计与实现 姓 名:学 号:专业班级: 移动 一 班 系 院: 软件学院设计时间: 2014.6.12014.6.4 目 录一、需求分析-3二、系统设计-3三、 程序流程图-10四、实现代码-13五、总结-23六、参考书目-23. z.-一、 需求分析哈夫曼编码是一种应用广泛且非常有效的数据压缩技术,哈夫曼编码是一种编码方式,以哈夫曼树,带权路径长度最小的二叉树,经常应用于数据压缩。哈夫曼编码使用一特殊的编码表将源字符进展编码。这编码表的特殊在于,它是根据每一个源字符出现的估算概率而建立起来的。哈夫曼编码的应用很

2、广泛,利用哈夫曼树求得的用于通信的二进制编码成为哈夫曼编码,树中从根到每个叶子都有一条路径,对路径上的各分支约定:指向左子树的分支表示0码,指向右子树的分支表示1码,取每条路径上的0或1的序列作为和各个叶子对应的字符的编码,这就是哈夫曼编码。哈夫曼译码输入字符串可以把它编译成二进制代码。输入二进制代码时可以编译成字符串。二、 系统设计构造哈夫曼树时,使用静态链表作为哈夫曼树的存储。在构造哈夫曼树时,设计一个构造体数组HuffNode保存哈夫曼树中各结点的信息,根据二叉树的性质可知,具有n个叶子结点的哈夫曼树共有2n-1个结点,所以数组HuffNode的大小设置为2n-1,求哈夫曼编码时使用一维

3、构造数组HuffCode作为哈夫曼编码信息的存储。求哈夫曼编码实际上就是在已建立的哈夫曼树中,从叶子结点开场,沿结点的双亲链域回退到根结点,每回退一步,就走过了哈夫曼的一个分支,从而得到一位哈夫曼编码值。由于一个字符的哈夫曼编码就是从根结点到相应叶子结点所经过的路径上各分支所组成的0、1序列,因此先得到的分支代码为所求编码的低位码,后得到的分支代码为所求的高位码1、初始化功能模块此功能模块的功能为从键盘承受字符集大小n,以及n个字符和n个权值。2、建立哈夫曼编码的功能模块此模块功能为使用1中得到的数据按照教材中的构造哈弗曼的算法构造哈弗曼树,即将HuffNode数组中的各个位置的各个域都填上相

4、关的值,并将这个构造体数组存于文件nodedata.dat中。函数原型为:void Creat_Haffmantree(int &n)HNodeType *HaffNode=new HNodeType2*n-1;int i,j;int m1,m2,x1,x2;for(i=0;i2*n-1;i+)HaffNodei.weight=0;HaffNodei.parent=-1;HaffNodei.lchild=-1;HaffNodei.rchild=-1;HaffNodei.inf=0;for(i=0;in;i+)cout请输入字符HaffNodei.inf;cout请输入该字符的权值HaffNod

5、ei.weight;for(i=0;in-1;i+)/构造哈夫曼树m1=m2=Maxvalue;x1=x2=0;for(j=0;jn+i;j+)/选取最小和次小if(HaffNodej.parent=-1&HaffNodej.weightm1)m2=m1;x2=x1;m1=HaffNodej.weight;x1=j;elseif(HaffNodej.parent=-1&HaffNodej.weightm2)m2=HaffNodej.weight;x2=j;/将找出的最小和次小合并,创造其父母结点HaffNodex1.parent=n+i;HaffNodex2.parent=n+i;HaffNo

6、den+i.weight=HaffNodex1.weight+HaffNodex2.weight;HaffNoden+i.lchild=x2;HaffNoden+i.rchild=x1;HaffNoden+i.inf=NULL;cout显示存储的哈弗曼树信息:endl; cout权值左孩子右孩子双亲endl; for(i=0;i2*n-1;i+) coutHaffNodei.inf ; coutHaffNodei.weight ; coutHaffNodei.lchild ; coutHaffNodei.rchild ; coutHaffNodei.parentendl;/写入文件fstrea

7、m outfile1;outfile1.open(E:nodedata.dat,ios:out|ios:trunc|ios:binary);/建立进展写入的文件if(!outfile1) /没有创立成功那么显示相应信息coutnodedata.dat文件不能翻开endl;abort();for(i=0;i2*n-1;i+) /将存中从HaffNodei地址开场的sizeof(HaffNodei)的容写入文件中outfile1.write(char*)&HaffNodei,sizeof(HaffNodei);outfile1.close ();/关闭文件delete HaffNode;3、建立哈

8、弗曼编码功的功能模块此模块功能是从文件nodedata.dat中读入相关的字符信息进展哈弗曼编码,然后将结果存入code.dat中,同时将字符与0和1代码串的一一对应关系显示到屏幕上。函数原型为:void HaffCode(int &n)/哈夫曼编码HNodeType *HaffNode=new HNodeTypeMaxnode;HcodeType *HaffCode=new HcodeTypeMaxleaf;HcodeType cd;int i,j,c,p;fstream in(E:nodedata.dat,ios:in|ios:binary);in.read(char*)HaffNode,

9、(2*n-1)*sizeof(HNodeType);in.close();fstream outfile;outfile.open(E:codedata.dat,ios:out|ios:binary);/建立进展写入的文件for(i=0;in;i+)cd.start=n-1;c=i;p=HaffNodec.parent;while(p!=-1)if(HaffNodep.lchild=c)cd.bitcd.start=0;elsecd.bitcd.start=1;cd.start-;c=p;p=HaffNodec.parent;for(j=cd.start+1;jn;j+)HaffCodei.b

10、itj=cd.bitj;HaffCodei.start=cd.start;for(i=0;in;i+) outfileHaffNodei.inf;for(j=HaffCodei.start+1;jn;j+)outfileHaffCodei.bitj; cout字符信息-编码信息endl; for(i=0;in;i+) coutHaffNodei.inf-; for(j=HaffCodei.start+1;jn;j+) coutHaffCodei.bitj; coutendl; outfile.close ();cout请输入要编码的字符串,根本元素为;for(i=0;in;i+)coutHaf

11、fNodei.inf,;cout)inf;int f=strlen(inf);fstream outfile1;outfile1.open(E:code.dat,ios:out|ios:binary);/建立进展写入的文件if(!outfile1) coutcode.dat文件不能翻开!endl; abort(); else coutendl; cout字符串编码后为:; for(int x=0;xf;x+) for(i=0;in;i+) if(infx=HaffNodei.inf) for(j=HaffCodei.start+1;jn;j+) outfile1.write(char*)&HaffCodei.bitj,sizeof(HaffCodei.bitj); coutHaffCodei.bitj; coutendl; cout编译后的代码串已经存入code.dat文件中!endl; coutendl; outfile1.close(); delete HaffNode;delete HaffCode;4. 此模块功能为接收需要译码的0、1代码串,按照3中建立的编码规那么将其翻译成字符集中字符所组成的字符串形式,存入文件textfile.dat,同时将翻译的结果

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 建筑/环境 > 施工组织

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号