C语言-哈夫曼编码实验报告.docx

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
C C语言- 哈夫曼编码实验报告 PAGE PAGE 11 福 建 工 程 学 院 课 题专 程: 目: 业: 数据结构 哈夫曼编码和译码信息管理信息系统 班 级: 1002 班 座 号: 15 号 姓 名: 林左权 课程设计2011 年 6 月 27 日 课程设计 实验题目:哈夫曼编码和译码 一、要解决的问题 利用哈夫曼编码进行信息通信可以大大提高信道利用率,缩短信息传输时间,降低传输成本。但是,这要求在发送端通过一个编码系统对待传数据预先编码,在 接收端将传来的数据进行译码 (复原)。对于双工信道(即可以双向传输信息的信道) ,每端都需要一个完整的编 / 译码系统。 二、算法基本思想描述: 根据给定的字符和其中每个字符的频度 ,构造哈夫馒树,并输出字符集中每个字符的哈夫曼编码 .将给定的字符串根据其哈夫曼编码进行编码 ,并进行相应的译码 . 三、设计 1. 数据结构的设计 (1)哈夫曼树的表示 设计哈夫曼树的结构体( htnode ),其中包含权重、左右孩子、父母和要编码的字符。用这个结构体( htnode )定义个哈夫曼数组( hfmt[] )。 迷宫定义如下: typedef struct { int weight; int lchild; int rchild; int parent; char key; }htnode; typedef htnode hfmt[MAXLEN]; )对原始字符进行编码 初始化哈夫曼树( inithfmt )。 从终端读入字符集大小 n,以及 n 个字符和 n 个权值, 建立哈夫曼树。 并显示出每个字符的编码。 void inithfmt(hfmt t)// 对结构体进行初始化 void inputweight(hfmt t)// 输入函数 void selectmin(hfmt t,int i,int *p1,int *p2)// 选中两个权值最小的函数 void creathfmt(hfmt t)// 创建哈夫曼树的函数 void phfmnode(hfmt t)// 对字符进行初始编码 )对用户输入的字符进行编码 void encoding(hfmt t)// 对用户输入的电文进行编码 { char r[1000];// 用来存储输入的字符串 int i,j; printf(\n\n 请输入需要编码的字符 :); gets(r); printf( 编码结果为 :); for(j=0;r[j]!=\0;j++) for(i=0;in;i++) if(r[j]==t[i].key) hfmtpath(t,i,j); printf(\n); } )对用户输入的字符进行编码 void decoding(hfmt t)// 对用户输入的密文进行译码 { char r[100]; int i,j,len; j=2*n-2;//j 初始从树的根节点开始printf(\n\n 请输入需要译码的字符串 :); gets(r); len=strlen(r); printf( 译码的结果是 :); for(i=0;ilen;i++) { if(r[i]==0) { j=t[j].lchild; if(t[j].lchild==-1) { printf(%c,t[j].key); j=2*n-2; } } else if(r[i]==1) { j=t[j].rchild; if(t[j].rchild==-1) { printf(%c,t[j].key); j=2*n-2; } } } printf(\n\n); } 四、源程序清单: #include stdio.h #include stdlib.h #include string.h #define MAXLEN 100 typedef struct { int weight; int lchild; int rchild; int parent; char key; }htnode; typedef htnode hfmt[MAXLEN]; int n; void inithfmt(hfmt t)// 对结构体进行初始化 { int i; printf(\n); printf( \n); printf(****************************** 输 入 区 ******************************\n); printf(\n 请输入 n=); scanf(%d,n); getchar(); for(i=0;i2*n-1;i++)// 对结构体进行初始化 { t[i].weight=0; t[i].lchild=-1; t[i].rchild=-1; t[i].parent=-1; } printf

文档评论(0)

文档查询,农业合作 + 关注
官方认证
内容提供者

该用户很懒,什么也没介绍

认证主体土默特左旗农特农机经销部
IP属地河北
统一社会信用代码/组织机构代码
92150121MA0R6LAH4P

1亿VIP精品文档

相关文档