欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    哈夫曼树---实验报告(共5页).docx

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

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

    哈夫曼树---实验报告(共5页).docx

    精选优质文档-倾情为你奉上计算机科学与技术学院 数据结构 实验报告班级 2014级计算机1班 学号 姓名 张建华 成绩 实验项目 简单哈夫曼编/译码的设计与实现 实验日期 2016.1.5一、实验目的本实验的目的是进一步理解哈夫曼树的逻辑结构和存储结构,进一步提高使用理论知识指导解决实际问题的能力。二、实验问题描述利用哈夫曼编码进行通信可以大大提高信道利用率,缩短信息传输时间,降低传输成本。但是,这要求在发送端通过一个编码系统对待传数据预先编码,在接收端将传来的数据进行译码,此实验即设计这样的一个简单编/码系统。系统应该具有如下的几个功能:1、接收原始数据。 从终端读入字符集大小n,以及n个字符和n个权值,建立哈夫曼树,并将它存于文件hfmtree.dat中。 2、编码。 利用已建好的哈夫曼树(如不在内存,则从文件hfmtree.dat中读入),对文件中的正文进行编码,然后将结果存入文件codefile.dat中。 3、译码。 利用已建好的哈夫曼树将文件codefile.dat中的代码进行译码,结果存入文件textfile.dat中。4、打印编码规则。 即字符与编码的一一对应关系。 5、打印哈夫曼树, 将已在内存中的哈夫曼树以直观的方式显示在终端上。 三、实验步骤1、实验问题分析1、构造哈夫曼树时使用静态链表作为哈夫曼树的存储。 在构造哈夫曼树时,设计一个结构体数组HuffNode保存哈夫曼树中各结点的信息,根据二叉树的性质可知,具有n个叶子结点的哈夫曼树共有2n-1个结点,所以数组HuffNode的大小设置为2n-1,描述结点的数据类型为: Typedef strcut Int weight;/*结点权值*/ Int parent; Int lchild; Int rchild; HNodeType; 2、求哈夫曼编码时使用一维结构数组HuffCode作为哈夫曼编码信息的存储。 求哈夫曼编码,实质上就是在已建立的哈夫曼树中,从叶子结点开始,沿结点的双亲链域回退到根结点,没回退一步,就走过了哈夫曼树的一个分支,从而得到一位哈夫曼码值,由于一个字符的哈夫曼编码是从根结点到相应叶子结点所经过的路径上各分支所组成的0、1序列,因此先得到的分支代码为所求编码的低位码,后得到的分支代码位所求编码的高位码,所以设计如下数据类型: #define MAXBIT 10 Typedef struct Int bitMAXBIT; Int start; HCodeType;3、文件hfmtree.dat、codefile.dat和textfile.dat。 2、功能(函数)设计(1)、初始化功能模块。 此功能模块的功能为从键盘接收字符集大小n,以及n个字符和n个权值。 (2)、建立哈夫曼树的功能模块。 此模块功能为使用1中得到的数据按照教材中的构造哈夫曼树的算法构造哈夫曼树,即将HuffNode数组中的各个位置的各个域都添上相关的值,并将这个结构体数组存于文件hfmtree.dat中。 (3)、建立哈夫曼编码的功能模块。 此模块功能为从文件hfmtree.dat中读入相关的字符信息进行哈夫曼编码,然后将结果存入codefile.dat中,同时将字符与0、1代码串的一一对应关系打印到屏幕上。 (4)、译码的功能模块。 此模块功能为接收需要译码的0、1代码串,按照3中建立的编码规则将其翻译成字符集中字符所组成的字符串形式,存入文件textfile.dat,同时将翻译的结果在屏幕上打印输出。 (5)、打印哈夫曼树的功能模块。 此模块功能为从HuffNode数组中读入相关的结点信息,以图形的方式将各个结点以及叶子结点的权值和左分支上的0和右分支上的1画出来。 四、实验结果(程序)及分析1、实验主要代码typedef struct /*结点结构体*/ string hfmstr; /*结点内容*/int weight; /*结点权值*/ int parent; int lchild; int rchild;HNodeType; typedef struct /* 编码结构体 */ int bitMAXBIT; int start;HCodeType; void Create_HuffMTree(HNodeType HFMTree,int n) /*创建哈夫曼树*/int m1,x1,m2,x2;int i,j;for(i=0;i<2*n-1;i+)HFMTreei.hfmstr=""HFMTreei.weight=0;HFMTreei.parent=-1;HFMTreei.lchild=-1;HFMTreei.rchild=-1;for(i=0;i<n;i+) cout<<"请输入第"<<i+1<<"个权值"<<endl;cin>>HFMTreei.weight;cout<<"请输入对应字符"<<endl;cin>>HFMTreei.hfmstr;for(i=0;i<n-1;i+)x1=x2=MAXVALUE;m1=m2=0;for(j=0;j<n+i;j+)if(HFMTreej.parent=-1&&HFMTreej.weight<x1)x2=x1;m2=m1;x1=HFMTreej.weight;m1=j;else if(HFMTreej.parent=-1&&HFMTreej.weight<x2)x2=HFMTreej.weight;m2=j;HFMTreem1.parent=n+i;HFMTreem2.parent=n+i;HFMTreen+i.weight=HFMTreem1.weight+HFMTreem2.weight;HFMTreen+i.lchild=m1;HFMTreen+i.rchild=m2; cout<<"创建哈夫曼树成功!"<<endl;void HaffmanCode(HNodeType HFMTree,HCodeType HuffCode,int n) /*构建哈夫曼编码*/HCodeType cd;int i,j,c,p; for(i=0;i<n;i+) cd.start=n-1; c=i; p=HFMTreec.parent; while(p!=-1) if(HFMTreep.lchild=c) cd.bitcd.start=0; else cd.bitcd.start=1; cd.start-; c=p; p=HFMTreec.parent; for(j=cd.start+1;j<n;j+) HuffCodei.bitj = cd.bitj; HuffCodei.start = cd.start; void decodeing(char string,HNodeType HFMTree,int n) /*解码*/ int i,tmp=0,code1024; int m=2*n-1; char *nump; char num1024; for(i=0;i<strlen(string);i+) if(stringi='0') numi=0; else numi=1; i=0; nump=&num0; while(nump<(&numstrlen(string) tmp=m-1; while(HFMTreetmp.lchild!=-1)&&(HFMTreetmp.rchild!=-1) if(*nump=0) tmp=HFMTreetmp.lchild ; else tmp=HFMTreetmp.rchild; nump+; cout<<HFMTreetmp.hfmstr; cout<<endl;2、测试数据与输出专心-专注-专业

    注意事项

    本文(哈夫曼树---实验报告(共5页).docx)为本站会员(飞****2)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

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




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开