- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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)