ImageVerifierCode 换一换
格式:DOCX , 页数:15 ,大小:308.35KB ,
资源ID:26821023      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/26821023.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(C语言哈夫曼编码实验报告.docx)为本站会员(b****3)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

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

1、C语言哈夫曼编码实验报告福 建 工 程 学 院课程设计课 程: 数据结构 题 目: 哈夫曼编码和译码 专 业: 信息管理信息系统 班 级: 1002班 座 号: 15号 姓 名: 林左权 2011年 6月 27日实验题目:哈夫曼编码和译码一、要解决的问题利用哈夫曼编码进行信息通信可以大大提高信道利用率,缩短信息传输时间,降低传输成本。但是,这要求在发送端通过一个编码系统对待传数据预先编码,在接收端将传来的数据进行译码(复原)。对于双工信道(即可以双向传输信息的信道),每端都需要一个完整的编/译码系统。二、算法基本思想描述: 根据给定的字符和其中每个字符的频度,构造哈夫馒树,并输出字符集中每个字

2、符的哈夫曼编码.将给定的字符串根据其哈夫曼编码进行编码,并进行相应的译码.三、设计1. 数据结构的设计 (1)哈夫曼树的表示设计哈夫曼树的结构体(htnode),其中包含权重、左右孩子、父母和要编码的字符。用这个结构体(htnode)定义个哈夫曼数组(hfmt)。迷宫定义如下:typedef struct int weight; int lchild; int rchild; int parent; char key;htnode;typedef htnode hfmtMAXLEN; (2)对原始字符进行编码初始化哈夫曼树(inithfmt)。从终端读入字符集大小n,以及n个字符和n个权值,建

3、立哈夫曼树。并显示出每个字符的编码。1.void inithfmt(hfmt t)/对结构体进行初始化2.void inputweight(hfmt t)/输入函数3.void selectmin(hfmt t,int i,int *p1,int *p2)/选中两个权值最小的函数4.void creathfmt(hfmt t)/创建哈夫曼树的函数5.void phfmnode(hfmt t)/对字符进行初始编码(3)对用户输入的字符进行编码void encoding(hfmt t)/对用户输入的电文进行编码 char r1000;/用来存储输入的字符串 int i,j; printf(nn请输

4、入需要编码的字符:); gets(r); printf(编码结果为:); for(j=0;rj!=0;j+) for(i=0;in;i+) if(rj=ti.key) hfmtpath(t,i,j); printf(n); (4)对用户输入的字符进行编码void decoding(hfmt t)/对用户输入的密文进行译码 char r100; int i,j,len; j=2*n-2;/j初始从树的根节点开始 printf(nn请输入需要译码的字符串:); gets(r); len=strlen(r); printf(译码的结果是:); for(i=0;ilen;i+) if(ri=0) j=

5、tj.lchild; if(tj.lchild=-1) printf(%c,tj.key); j=2*n-2; else if(ri=1) j=tj.rchild; if(tj.rchild=-1) printf(%c,tj.key); j=2*n-2; printf(nn); 四、源程序清单:#include #include #include #define MAXLEN 100typedef struct int weight; int lchild; int rchild; int parent; char key;htnode;typedef htnode hfmtMAXLEN;in

6、t 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+)/对结构体进行初始化 ti.weight=0; ti.lchild=-1; ti.rchild=-1; ti.parent=-1; printf(n); void inputweight(hfmt t)/输入函数 int w;/w表示权值 int i; char k;/k表示获取的字符 for(i=0;in;i+)

7、printf(请输入第%d个字符:,i+1); scanf(%c,&k); getchar(); ti.key=k; printf(请输入第%d个字符的权值:,i+1); scanf(%d,&w); getchar(); ti.weight=w; printf(n); void selectmin(hfmt t,int i,int *p1,int *p2)/选中两个权值最小的函数 long min1=999999; long min2=999999; int j; for(j=0;jtj.weight) min1=tj.weight; *p1=j; for(j=0;jtj.weight & j

8、!=(*p1)/注意 j!=(*p1) min2=tj.weight; *p2=j; void creathfmt(hfmt t)/创建哈夫曼树的函数 int i,p1,p2; inithfmt(t); inputweight(t); for(i=n;i2*n-1;i+) selectmin(t,i-1,&p1,&p2); tp1.parent=i; tp2.parent=i; ti.lchild=p1; ti.rchild=p2; ti.weight=tp1.weight+tp2.weight; void printhfmt(hfmt t)/打印哈夫曼树 int i; printf(-n);

9、 printf(*哈夫曼编数结构:*n); printf(tt权重t父母t左孩子t右孩子t字符t); for(i=0;i2*n-1;i+) printf(n); printf(tt%dt%dt%dt%dt%c,ti.weight,ti.parent,ti.lchild,ti.rchild,ti.key); printf(n-n); printf(nn); void hfmtpath(hfmt t,int i,int j)/编码的重要哈夫曼树路径递归算法 int a,b; a=i; b=j=ti.parent; if(tj.parent!=-1) i=j; hfmtpath(t,i,j); if

10、(tb.lchild=a) printf(0); else printf(1); void phfmnode(hfmt t)/对字符进行初始编码 int i,j,a; printf(n-n); printf(*哈夫曼编码*); for(i=0;in;i+) j=0; printf(n); printf(tt%ct,ti.key,ti.weight); hfmtpath(t,i,j); printf(n-n); void encoding(hfmt t)/对用户输入的电文进行编码 char r1000;/用来存储输入的字符串 int i,j; printf(nn请输入需要编码的字符:); get

11、s(r); printf(编码结果为:); for(j=0;rj!=0;j+) for(i=0;in;i+) if(rj=ti.key) hfmtpath(t,i,j); printf(n); void decoding(hfmt t)/对用户输入的密文进行译码 char r100; int i,j,len; j=2*n-2;/j初始从树的根节点开始 printf(nn请输入需要译码的字符串:); gets(r); len=strlen(r); printf(译码的结果是:); for(i=0;ilen;i+) if(ri=0) j=tj.lchild; if(tj.lchild=-1) pr

12、intf(%c,tj.key); j=2*n-2; else if(ri=1) j=tj.rchild; if(tj.rchild=-1) printf(%c,tj.key); j=2*n-2; printf(nn); int main() int i,j; hfmt ht; char flag; printf( |-|n); printf( |信管1002-林左权-15号|n); printf( |*|n); printf( | 哈夫曼编码课程设计 |n); printf( |*|n); printf( |设计完成时间:2011/6/27|n); printf( |-|n); creathf

13、mt(ht); printhfmt(ht); phfmnode(ht); printf(n-n); printf(*编码&译码&退出*); printf(n【1】编码t【2】t译码t【0】退出); printf(n您的选择:); flag=getchar(); getchar(); while(flag!=0) if(flag=1) encoding(ht); else if(flag=2) decoding(ht); else printf(您的输入有误,请重新输入。n); printf(n*编码&译码&退出*); printf(n【1】编码t【2】t译码t【0】退出); printf(n您的选择:); flag=getchar(); getchar(); printf(nn-n); printf(*欢迎使用林左权的哈夫曼编码系统*n); printf(-n); system(pause);五、测试数据及测试结果: 例如:六、心得体会:(略)

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1