欢迎来到冰点文库! | 帮助中心 分享价值,成长自我!
冰点文库
全部分类
  • 临时分类>
  • IT计算机>
  • 经管营销>
  • 医药卫生>
  • 自然科学>
  • 农林牧渔>
  • 人文社科>
  • 工程科技>
  • PPT模板>
  • 求职职场>
  • 解决方案>
  • 总结汇报>
  • ImageVerifierCode 换一换
    首页 冰点文库 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    实验五 哈夫曼编码与译码的设计与实现.docx

    • 资源ID:17086301       资源大小:155.95KB        全文页数:34页
    • 资源格式: DOCX        下载积分:8金币
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录
    二维码
    微信扫一扫登录
    下载资源需要8金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,免费下载
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    实验五 哈夫曼编码与译码的设计与实现.docx

    1、实验五 哈夫曼编码与译码的设计与实现实验五 哈夫曼编码与译码的设计与实现一、问题描述利用哈夫曼编码进行通信可以大大提高信道利用率,缩短信息传输时间,降低传输成本。但是,这要求在发送端通过一个编码系统对待传数据预先编码,在接收端将传来的数据进行译码(复原)。对于双工信道(即可以双向传输信息的信道),每端都需要一个完整的编/译码系统。试为这样的信息收发编写一个哈夫曼码的编/译码系统。基本要求: (1)接收原始数据:从终端读入字符集大小n,以及n个字符和n个权值,建立哈夫曼树,并将它存于文件nodedata.dat中。 (2)编码:利用已建好的哈夫曼树(如不在内存,则从文件nodedata.dat中

    2、读入),对文件中的正文进行编码,然后将结果存入文件code.dat中。 (3)译码:利用已建好的哈夫曼树将文件code.dat中的代码进行译码,结果存入文件textfile.txt中。 (4)打印编码规则:即字符与编码的一一对应关系。 (5)打印哈夫曼树:将已在内存中的哈夫曼树以直观的方式显示在终端上。二、数据结构设计1、构造哈夫曼树时,使用静态链表作为哈夫曼树的存储。在构造哈夫曼树时,设计一个结构体数组HuffNode保存哈夫曼树中各结点的信息,根据二叉树的性质可知,具有n个叶子结点的哈夫曼树共有2n-1个结点,所以数组HuffNode的大小设置为2n-1,描述结点的数据类型为:typede

    3、f struct int weight; int parent; int lchild; int rchild; char inf;HNodeType;2.求哈夫曼编码时使用一维结构数组HuffCode作为哈夫曼编码信息的存储。求哈夫曼编码实际上就是在已建立的哈夫曼树中,从叶子结点开始,沿结点的双亲链域回退到根结点,每回退一步,就走过了哈夫曼的一个分支,从而得到一位哈夫曼编码值。由于一个字符的哈夫曼编码就是从根结点到相应叶子结点所经过的路径上各分支所组成的0、1序列,因此先得到的分支代码为所求编码的低位码,后得到的分支代码为所求的高位码。所以设计如下数据类型:#define MaxBit 10

    4、struct HcodeType int bitMaxBit; int start;3、文件nodedata.dat、code.dat、textfile.txt三、功能函数设计1、初始化功能模块此功能模块的功能为从键盘接受字符集大小n,以及n个字符和n个权值。2、建立哈夫曼编码的功能模块此模块功能为使用1中得到的数据按照教材中的构造哈弗曼的算法构造哈弗曼树,即将HuffNode数组中的各个位置的各个域都填上相关的值,并将这个结构体数组存于文件nodedata.dat中。函数原型为:void Creat_Haffmantree(int &n) HNodeType *HaffNode=new HN

    5、odeType2*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请输入该字符的权值HaffNodei.weight; for(i=0;in-1;i+)/构造哈夫曼树 m1=m2=Maxvalue; x1=x2=0; for(j=0;jn+i;j+)/选取最小和

    6、次小 if(HaffNodej.parent=-1&HaffNodej.weightm1) m2=m1; x2=x1; m1=HaffNodej.weight; x1=j; else if(HaffNodej.parent=-1&HaffNodej.weightm2) m2=HaffNodej.weight; x2=j; /将找出的最小和次小合并,创造其父母结点 HaffNodex1.parent=n+i; HaffNodex2.parent=n+i; HaffNoden+i.weight=HaffNodex1.weight+HaffNodex2.weight; HaffNoden+i.lch

    7、ild=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; /写入文件 fstream outfile1; outfile1.open(E:nodedata.dat,ios:out|ios:trunc|

    8、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、建立哈弗曼编码功的功能模块此模块功能是从文件nodedata.dat中读入相关的字符信息进行哈弗曼编码,

    9、然后将结果存入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,(2*n-1)*sizeof(HNodeType); in.close(); fstr

    10、eam 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; else cd.bitcd.start=1; cd.start-; c=p; p=HaffNodec.parent; for(j=cd.start+1;jn;j+) HaffCodei.bitj=cd.bitj; HaffCodei.sta

    11、rt=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+) coutHaffNodei.inf,; cout)

    12、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,

    13、sizeof(HaffCodei.bitj); coutHaffCodei.bitj; coutendl; cout编译后的代码串已经存入code.dat文件中!endl; coutendl; outfile1.close(); delete HaffNode; delete HaffCode;4. 此模块功能为接收需要译码的0、1代码串,按照3中建立的编码规则将其翻译成字符集中字符所组成的字符串形式,存入文件textfile.dat,同时将翻译的结果在屏幕上打印输出。接受0、1代码串有两种形式,一种是直接输入,一种是从文件中读取。函数原型为:void decode( int &n)/解码 i

    14、nt i; HNodeType *HaffNode=new HNodeType2*n-1; fstream infile1; infile1.open(E:nodedata.dat,ios:in|ios:binary);/读出哈夫曼树 if(!infile1) coutnodedata.dat文件不能打开endl; abort(); for(i=0;i2*n-1;i+) infile1.read(char*)&HaffNodei,sizeof(HNodeType); infile1.close(); int tempcode100; int num=0; for(i=0;i100;i+) te

    15、mpcodei=-1; HcodeType *Code=new HcodeTypen; cout请选择要做的操作:endl; cout输入串解码,请按4endl; cout从文件中解码,请按5q; while(q5|q4) coutq; switch(q) case 4: cout请输入要解码的0,1串(按其他键结束输入):tempcodei; while(tempcodei=0|tempcodei=1) i+; num=i; cintempcodei; cout输入的编码为:; for(i=0;inum;i+) couttempcodei; coutendl; int m=2*n-2; i=

    16、0; cout译码后为:endl; fstream outfile; outfile.open(E:textfile.txt,ios:out); if(!outfile) couttextfile.txt文件不能打开!endl; abort(); while(inum)/ 小于字符串的长度 while(HaffNodem.lchild!=-1&HaffNodem.rchild!=-1) if(tempcodei=0) m=HaffNodem.lchild; i+; else if(tempcodei=1) m=HaffNodem.rchild; i+; coutHaffNodem.inf; o

    17、utfileHaffNodem.inf; m=2*n-2; coutendl; outfile.close(); cout译码后的结果已经存入textfile.txt中!endl; delete HaffNode; break; case 5: fstream infile2;/读编码 infile2.open(E:code.dat,ios:in|ios:binary); while(!infile2.eof() infile2.read(char*)&tempcodenum,sizeof(tempcodenum); num+; infile2.close(); num-; cout从文件中读

    18、出的编码为endl; for(i=0;inum;i+) couttempcodei; coutendl; int m=2*n-2; i=0; coutendl; cout译码后为:endl; fstream outfile; outfile.open(E:textfile.txt,ios:out); if(!outfile) couttextfile.txt文件不能打开!endl; abort(); while(inum)/ 小于字符串的长度 while(HaffNodem.lchild!=-1&HaffNodem.rchild!=-1) if(tempcodei=0) m=HaffNodem

    19、.lchild; i+; else if(tempcodei=1) m=HaffNodem.rchild; i+; coutHaffNodem.inf; outfileHaffNodem.inf; m=2*n-2; coutendl; outfile.close(); cout译码后的结果已经存入textfile.txt中!endl; delete HaffNode; break; 四编码实现#include stdafx.h#include#include#include#includeusing namespace std;#define MaxBit 10#define Maxvalue

    20、 100/应该大于权重之和#define Maxleaf 100#define Maxnode Maxleaf*2-1typedef struct int weight; int parent; int lchild; int rchild; char inf;HNodeType;struct HcodeType int bitMaxBit; int start;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+) H

    21、affNodei.weight=0; HaffNodei.parent=-1; HaffNodei.lchild=-1; HaffNodei.rchild=-1; HaffNodei.inf=0; for(i=0;in;i+) cout请输入字符HaffNodei.inf; cout请输入该字符的权值HaffNodei.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;

    22、m1=HaffNodej.weight; x1=j; else if(HaffNodej.parent=-1&HaffNodej.weightm2) m2=HaffNodej.weight; x2=j; /将找出的最小和次小合并,创造其父母结点 HaffNodex1.parent=n+i; HaffNodex2.parent=n+i; HaffNoden+i.weight=HaffNodex1.weight+HaffNodex2.weight; HaffNoden+i.lchild=x2; HaffNoden+i.rchild=x1; HaffNoden+i.inf=NULL; cout显示存

    23、储的哈弗曼树信息:endl; cout权值左孩子右孩子双亲endl; for(i=0;i2*n-1;i+) coutHaffNodei.inf ; coutHaffNodei.weight ; coutHaffNodei.lchild ; coutHaffNodei.rchild ; coutHaffNodei.parentendl; /写入文件 fstream outfile1; outfile1.open(E:nodedata.dat,ios:out|ios:trunc|ios:binary);/建立进行写入的文件 if(!outfile1) /没有创建成功则显示相应信息 coutnode

    24、data.dat文件不能打开endl; abort(); for(i=0;i2*n-1;i+) /将内存中从HaffNodei地址开始的sizeof(HaffNodei)的内容写入文件中 outfile1.write(char*)&HaffNodei,sizeof(HaffNodei); outfile1.close ();/关闭文件 delete HaffNode; void HaffCode(int &n)/哈夫曼编码 HNodeType *HaffNode=new HNodeTypeMaxnode; HcodeType *HaffCode=new HcodeTypeMaxleaf; Hc

    25、odeType cd; int i,j,c,p; fstream in(E:nodedata.dat,ios:in|ios:binary); in.read(char*)HaffNode,(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; else cd.bitcd.start=1; cd.start-; c=p; p=HaffNodec.parent; for(j=cd.start+1;jn;j+) HaffCodei.bitj=cd.bitj;


    注意事项

    本文(实验五 哈夫曼编码与译码的设计与实现.docx)为本站会员主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2023 冰点文库 网站版权所有

    经营许可证编号:鄂ICP备19020893号-2


    收起
    展开