数据结构哈夫曼编码实验报告.docx

上传人:牧羊曲112 文档编号:3560071 上传时间:2023-03-13 格式:DOCX 页数:9 大小:39.95KB
返回 下载 相关 举报
数据结构哈夫曼编码实验报告.docx_第1页
第1页 / 共9页
数据结构哈夫曼编码实验报告.docx_第2页
第2页 / 共9页
数据结构哈夫曼编码实验报告.docx_第3页
第3页 / 共9页
数据结构哈夫曼编码实验报告.docx_第4页
第4页 / 共9页
数据结构哈夫曼编码实验报告.docx_第5页
第5页 / 共9页
亲,该文档总共9页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

《数据结构哈夫曼编码实验报告.docx》由会员分享,可在线阅读,更多相关《数据结构哈夫曼编码实验报告.docx(9页珍藏版)》请在三一办公上搜索。

1、数据结构哈夫曼编码实验报告数据结构实验报告 实验五 简单哈夫曼编/译码的设计与实现 本实验的目的是通过对简单哈夫曼编/译码系统的设计与实现来熟练掌握树型结构在实际问题中的应用。此实验可以作为综合实验,阶段性实验时可以选择其中的几个功能来设计和实现。 一、 利用哈夫曼编码进行通信可以大大提高信道利用率,缩短信息传输时间,降低传输成本。但是,这要求在发送端通过一个编码系统对待传数据预先编码,在接收端将传来的数据进行译码,此实验即设计这样的一个简单编/码系统。系统应该具有如下的几个功能: 1、接收原始数据。 从终端读入字符集大小n,以及n个字符和n个权值,建立哈夫曼树,并将它存于文件nodedata

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

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

4、 struct int bitMAXBIT; int start; HcodeType; 3、文件nodedata.dat、code.dat和textfile.dat。 三、 1、初始化功能模块。 此功能模块的功能为从键盘接收字符集大小n,以及n个字符和n个权值。 2、建立哈夫曼树的功能模块。 此模块功能为使用1中得到的数据按照教材中的构造哈夫曼树的算法构造哈夫曼树,即将HuffNode数组中的各个位置的各个域都添上相关的值,并将这个结构体数组存于文件hfmtree.dat中。 3、建立哈夫曼编码的功能模块。 此模块功能为从文件nodedata.dat中读入相关的字符信息进行哈夫曼编码,然后将

5、结果存入code.dat中,同时将字符与0、1代码串的一一对应关系打印到屏幕上。 4、译码的功能模块。 此模块功能为接收需要译码的0、1代码串,按照3中建立的编码规则将其翻译成字符集中字符所组成的字符串形式,存入文件textfile.dat,同时将翻译的结果在屏幕上打印输出。 四、 #include #include #include #include #define MaxBit 10 #define Maxvalue 100/应该大于权重之和 #define Maxleaf 100 #define Maxnode Maxleaf*2-1 typedef struct int weight;

6、 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+) HaffNodei.weight=0; HaffNodei.parent=-1; HaffNodei.lchild=-1; HaffNodei.rchild=-1

7、; 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; m1=HaffNodej.weight; x1=j; else if(HaffNodej.parent=-1&HaffNodej.weightm2) m2=Ha

8、ffNodej.weight; x2=j; /将找出的最小和次小合并,创造其父母结点 HaffNodex1.parent=n+i; HaffNodex2.parent=n+i; HaffNoden+i.weight=HaffNodex1.weight+HaffNodex2.weight; HaffNoden+i.lchild=x1; HaffNoden+i.rchild=x2; HaffNoden+i.inf=NULL; cout显示存储的哈弗曼树信息:endl; cout权值 左孩子 右孩子 双亲endl; for(i=0;i2*n-1;i+) coutHaffNodei.weight ;

9、coutHaffNodei.lchild ; coutHaffNodei.rchild ; coutHaffNodei.parent ; coutHaffNodei.infendl; /写入文件 fstream 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(Haff

10、Nodei)的内容写入文件中 outfile1.write(char*)&HaffNodei,sizeof(HaffNodei); outfile1.close ;/关闭文件 delete HaffNode; 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(ch

11、ar*)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=c

12、d.start+1;jn;j+) HaffCodei.bitj=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请输入要编码的

13、字符串,基本元素为(; for(i=0;in;i+) coutHaffNodei.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.st

14、art+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; void decode( int &n)/解码 int i; HNodeType *HaffNode=new HNodeType2*n-1; fstream infile1; infile1.open(E:

15、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+) tempcodei=-1; HcodeType *Code=new HcodeTypen; fstream infile2;/读编码 infile2.open(E:co

16、de.dat,ios:in|ios:binary); while(!infile2.eof) infile2.read(char*)&tempcodenum,sizeof(tempcodenum); num+; infile2.close; num-; cout从文件中读出的编码为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)

17、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; outfileHaffNodem.inf; m=2*n-2; coutendl; outfile.close; cout译码后的结果已经存入textfile.txt中!endl;

18、 delete HaffNode; int main int n; cout* 欢迎进入编/译码系统!*endl; int ch1; do cout 1.建树endl; cout 2:编码,并显示字符和对应的编码endl; cout 3:译码endl; cout 0:退出endl; cout*endl; coutch1; while(!(ch1=0) /输入不在0到4之间无效 coutch1; switch(ch1) case 1: coutttt请输入编码个数n; Creat_Haffmantree(n); break; case 2: HaffCode(n); break; case 3: decode(n); break; while(ch1!=0); return 0; 五、 1、令叶子结点个数n为4,权值集合为1,3,5,7,字符集合为A,B,C,D,并有如下对应关系,A1、B3,C5,D7,调用初始化功能模块可以正确接收这些数据。 2、调用建立哈夫曼树的功能模块,构造静态链表HuffNode的存储。 3、调用建立哈夫曼编码的功能模块,在屏幕上显示如下对应关系: A111、B110、C10、D0 4、调用译码的功能模块,输入代码串“111110100”后,屏幕上显示译码结果: 111110100 ABCD

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 生活休闲 > 在线阅读


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号