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

    哈夫曼编码和译码的设计与实现.pdf

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

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

    哈夫曼编码和译码的设计与实现.pdf

    哈夫曼编码和译码的设计与实现1/13 算法与数据结构课程设计哈夫曼编码和译码的设计与实现1.问题描述利用哈夫曼编码进行通信可以大大提高信道的利用率,缩短信息传输时间,降低传输成本。但是,这要求在发送端通过一个编码系统对待传数据预先编码,在接收端将传来的数据进行译码(复原)。对于双工信道(即可以双向传输信息的信道),每端都需要一个完整的编/译码系统。试为这样的信息收发站设计一个哈夫曼码的编/译码系统。哈夫曼编码和译码的设计与实现2/13 2.基本要求a.编/译码系统应具有以下功能:(1)I:初始化(Initialization)。从终端读入字符集大小n,以及 n 个字符和 n 个权值,建立哈夫曼树,并将它存于文件hfmTree 中。(2)E:编码(Encoding)。利用已建好的哈夫曼树(如不在内存,则从文件 hfmTree 中读入),对文件 ToBeTran中的正文进行编码,然后将结果存入文件 CodeFile 中。(3)D:译码(Decoding)。利用已建好的哈夫曼树将文件CodeFile 中的代码进行译码,结果存入文件TextFile中。(4)P:印代码文件(Print)。将文件 CodeFile 以紧凑格式显示在终端上,每行 50 个代码。同时将此字符形式的编码文件写入文件CodePrin中。(5)T:印哈夫曼树(Tree printing)。将已在内存中的哈夫曼树以直观的方式(树或凹入表形式或广义表)显示在终端上,同时将此字符形式的哈夫曼树写入文件TreePrint中。b.测试数据(1)利用下面这道题中的数据调试程序。某系统在通信联络中只可能出现八种字符,其概率分别为 0.25,0.29,0.07,0.08,0.14,0.23,0.03,0.11,试设计哈夫曼编码。(2)用下表给出的字符集和频度的实际统计数据建立哈夫曼树,并实现以下报文的编码和译码:“THIS PROGRAM IS MY FAVORITE”。字符空格 A B C D E F G H I J K L M 频度 186 64 13 22 32 103 21 15 47 57 1 5 32 20 字符 N O P Q R S T U V W X Y Z 频度57 63 15 1 48 51 80 23 8 18 1 16 13需求分析3.1 程序的基本功能本程序可以对任何大小的字符型文件进行Huffman 编码,生成一个编码文件。并可以在程序运行结束后的任意时间对它解码还原生成字符文件。即:先对一条电文进行输入,并实现 Huffman 编码,然后对 Huffman 编码生成的代码串进行译码,最后输出电文数字哈夫曼编码和译码的设计与实现3/13 3.2输入/输出形式当进行编码时输入为原字符文件文件名,当程序运行编码完成之后输入编码文件名(默认名为 code.dll)。当进行译码时输入为编码文件名(默认名为code.dll),从文件中读取Huffman编码树后输入字符文件的文件名。3.3测试数据要求本程序中测试数据主要为字符型文件。4概要设计1.系统结构图(功能模块图)2功能模块说明(1).编码:提示要编码的文件文件名读取文件以字母出现次数为权值建立哈弗曼树对文本进行哈弗曼编码并输出编码提示将编码保存的文件名保存编码文件;(2).译码:提示输入要译码的文件名利用建立好的哈弗曼树进行译码将译码输出提示保存译码文件的文件名保存译码文件;(3).退出:退出系统,程序运行结束。5详细设计创建哈弗曼树哈弗曼树编码译码器编码译码退出哈夫曼编码和译码的设计与实现4/13 编码开始初始化哈夫曼链表且有 2n-1 个节点i=1 Iweight=counti p=p-next for(i=n;iParent=HT2-Parent=p p-LChild=HT1 p-RChild=HT2 p-weight=HT1-weight+HT2-结束哈夫曼编码和译码的设计与实现5/13 译码开始将 字 符 存 入 哈 夫曼 编 码 结 构 体 数组的字符单元中if(q=q-Parent-LChild)HCi.code-HCi.start=0 HCi.code-HCi.start=1 p=p-next I=n 时结束哈夫曼编码和译码的设计与实现6/13 6调试分析1.从叶子节点开始向上遍历二叉树,获得哈夫曼编码;2.根据哈夫曼编码遍历哈夫曼树直到叶子节点,获得译码3.算法的时间复杂度分析:程序部分用双循环嵌套结构,时间复杂度为 O(n2).4算法的空间复杂度分析:算法的空间复杂度为O(n)5.程序需要反复调试,并且调试过程比较慢,需要有一个比较正确的调试方法,更需要我们有耐心7用户使用说明开始Root 指向根节点P!=root codei=0 p=p-LChild p=p-Rchild p-LChild=NULL&p-RChild=NULL sk+=strj p=root 结束哈夫曼编码和译码的设计与实现7/13 1.输入字符的个数n 2 输入 n 个字符和 n 个权值3 选择(15)操作可对 huffman 树进行编码和译码以及huffman 树表的打印4 退出系统8测试结果哈夫曼编码和译码的设计与实现8/13 哈夫曼编码和译码的设计与实现9/13 9附录#include stdio.h#include stdlib.h#include string.h#define MAX 100 struct HafNode int weight;int parent;char ch;int lchild;int rchild;*myHaffTree;struct Coding char bitMAX;char ch;int weight;*myHaffCode;void Haffman(int n)/*构造哈弗曼树*/int i,j,x1,x2,s1,s2;for(i=n+1;i=2*n-1;i+)哈夫曼编码和译码的设计与实现10/13 s1=s2=10000;x1=x2=0;for(j=1;j=i-1;j+)if(myHaffTreej.parent=0&myHaffTreej.weights1)s2=s1;x2=x1;s1=myHaffTreej.weight;x1=j;else if(myHaffTreej.parent=0&myHaffTreej.weights2)s2=myHaffTreej.weight;x2=j;myHaffTreex1.parent=i;myHaffTreex2.parent=i;myHaffTreei.weight=s1+s2;myHaffTreei.lchild=x1;myHaffTreei.rchild=x2;void HaffmanCode(int n)int start,c,f,i,j,k;char*cd;cd=(char*)malloc(n*sizeof(char);myHaffCode=(struct Coding*)malloc(n+1)*sizeof(struct Coding);cdn-1=0;for(i=1;i=n;+i)start=n-1;for(c=i,f=myHaffTreei.parent;f!=0;c=f,f=myHaffTreef.parent)if(myHaffTreef.lchild=c)cd-start=0;else cd-start=1;for(j=start,k=0;jn;j+)myHaffCodei.bitk=cdj;k+;myHaffCodei.ch=myHaffTreei.ch;哈夫曼编码和译码的设计与实现11/13 myHaffCodei.weight=myHaffTreei.weight;free(cd);void print()printf(*n);printf(*n);printf(*n);printf(*welcome to huffman coding and codeprinting*n);printf(*n);printf(*n);printf(*1.init 2.coding 3.codeprinting 4.print the huffman 5.exit*n);printf(*n);printf(*n);Init()int i,n,m;printf(now initn);printf(please input the number of words:n);scanf(%d,&n);m=2*n-1;myHaffTree=(struct HafNode*)malloc(sizeof(struct HafNode)*(m+1);for(i=1;i=n;i+)printf(please input the word and the equal:n);scanf(%s%d,&myHaffTreei.ch,&myHaffTreei.weight);myHaffTreei.parent=0;myHaffTreei.lchild=0;myHaffTreei.rchild=0;for(i=n+1;i=m;i+)myHaffTreei.ch=#;myHaffTreei.lchild=0;myHaffTreei.parent=0;myHaffTreei.rchild=0;哈夫曼编码和译码的设计与实现12/13 myHaffTreei.weight=0;Haffman(n);HaffmanCode(n);for(i=1;i=n;i+)printf(%c%d,myHaffCodei.ch,myHaffCodei.weight);printf(n);printf(init success!n);return n;void Caozuo_C(int m)/*对字符进行编码*/int n,i,j;char string50,*p;printf(please input the words:n);scanf(%s,string);n=strlen(string);for(i=1,p=string;i=n;i+,p+)for(j=1;j=m;j+)if(myHaffCodej.ch=*p)printf(%sn,myHaffCodej.bit);void Caozuo_D(int n)int i,c;char code1000,*p;printf(please input the coding:n);scanf(%s,code);for(p=code,c=2*n-1;*p!=0;p+)if(*p=0)c=myHaffTreec.lchild;if(myHaffTreec.lchild=0)printf(%c,myHaffTreec.ch);c=2*n-1;continue;哈夫曼编码和译码的设计与实现13/13 else if(*p=1)c=myHaffTreec.rchild;if(myHaffTreec.lchild=0)printf(%c,myHaffTreec.ch);c=2*n-1;continue;printf(n);void Caozuo_T(int n)int i;printf(word equal leftchild rightchild prentsn);for(i=1;i=2*n-1;i+)printf(%c%d%d%d%dn,myHaffTreei.ch,myHaffTreei.weight,myHaffTreei.lchild,myHaffTreei.rchild,myHaffTreei.parent);main()int n;char char1;print();n=Init();while(1)printf(A.coding B.codeprinting C.print the huffman D.exitnplease input the process:n);scanf(%s,&char1);if(char1=D)break;switch(char1)caseA:Caozuo_C(n);break;/*执行编码操作*/caseB:Caozuo_D(n);break;/*执行译码操作*/caseC:Caozuo_T(n);break;/*打印哈弗曼树*/

    注意事项

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

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




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

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

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

    收起
    展开