




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、广州中医药大学医学信息工程学院实 验 报 告课程名称:数据结构与算法专业班级:计算机科学与技术( )级学生学号:学生姓名:实验名称:实验成绩:课程类别:必修þ 限选 公选 其它 哈夫曼编码及应用实验目的:了解哈夫曼树的应用,掌握哈夫曼树的构造方法及前缀码的应用。实验性质:设计性,应用性。实验步骤: (1) 输入一串字符,统计其中所有的不同字符及其个数,得出每个不同字符在文中出现的频率。(2) 根据每个字符频率建立哈夫曼树,输出字符对应的编码。实验要求 1、 实验要求独立完成。2、 迟交或不交的或源代码雷同者一律不做作业登记评分。作业提交 (实验报告写在此处)给出含有6,8,11个字符
2、的实例,统计他们的频率,画出哈夫曼树,并用算法验证结果。624D1C11B2A21)1代码写在此处#include"stdio.h"#include<malloc.h>#define MAXNODE 20#define MAXLEAF 30#define MAXINT 234567struct HtNodeint ww;int parent,lchild,rchild;struct HtTreeint root;struct HtNode htMAXNODE;typedef struct HtTree PHtTree;PHtTree *huffman(int m
3、,int *w);void main() char sMAXNODE; int m=0;char wMAXNODE; int count=0; int t=0; int aMAXNODE; int *b; char *code;code=(char *)malloc(sizeof(char); b=(int *)malloc(sizeof(int); printf("请输入字符窜:n"); for(int i=0;i<MAXNODE;i+) scanf("%c ",&si); +count; if(si='#') break
4、; for(i=0;i<count-1;i+) ai=0;bm=0; for(int j=0;j<count-1;j+) if(si=sj&&i<=j) ai=ai+1; if(si=sj&&i>j) ai=ai+1; si=NULL; if(si!=NULL) bm=ai; wm=si; m+; printf("%c的个数%d,频率为%fn",wm-1,bm-1,(float)ai/(count-1); PHtTree *pht; pht=(PHtTree *)malloc(sizeof(PHtTree); pht=
5、huffman(m,b); for(i=0;i<2*m-1;i+) printf("%d",pht->hti.ww); printf("n");for(i=0;i<m;i+) int c;c=i;t=0;intp=pht->hti.parent;while(p!=-1)if(pht->htp.lchild=c) codet='0' t+;if(pht->htp.rchild=c)codet='1' t+; pht->root-; c=p;p=pht->htp.parent;p
6、rintf("%c的编码是",wi);for(int y=t-1;y>=0;y-)printf("%c",codey);printf("n");PHtTree *huffman(int m,int *w)/构造具有m各节点的哈弗曼树 PHtTree *pht; int i,j,x1,x2,m1,m2; pht=(PHtTree *)malloc(sizeof(PHtTree); if(pht=NULL) printf("out of space!n"); return pht; for(i=0;i<2*
7、m-1;i+) pht->hti.lchild=-1; pht->hti.rchild=-1; pht->hti.parent=-1;if(i<m)pht->hti.ww=wi;elsepht->hti.ww=-1;for(i=0;i<m-1;i+)m1=MAXINT;m2=MAXINT;x1=-1;x2=-1;for(j=0;j<m+i;j+)if(pht->htj.ww<m1&&pht->htj.parent=-1)m2=m1;x2=x1;m1=pht->htj.ww;x1=j;else if(pht->htj.ww<m2&&pht->htj.parent=-1)m2=pht->htj.ww; x2=j;pht->htx1.parent=m+i;pht->htx2.parent=m+i;pht->htm+i.ww=m1
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- TY/T 2101-2024体育场馆智慧化信息系统配置要求
- 智慧城市课题申报书
- 省级中学课题申报书格式
- 篮球特色课题申报书
- 班干部申请书模板
- 员工加工合同范本
- 人生导师合同范例
- 译者的课题申报书
- 合作伙伴现金交易合同范例
- 吴江区试用期劳动合同范本
- 16防冲工题库题库(238道)
- 2023年常州工业职业技术学院高职单招(语文)试题库含答案解析
- GB/T 3452.2-2007液压气动用O形橡胶密封圈第2部分:外观质量检验规范
- GB/T 30797-2014食品用洗涤剂试验方法总砷的测定
- GB/T 20057-2012滚动轴承圆柱滚子轴承平挡圈和套圈无挡边端倒角尺寸
- GB/T 19808-2005塑料管材和管件公称外径大于或等于90mm的聚乙烯电熔组件的拉伸剥离试验
- GB/T 10051.1-2010起重吊钩第1部分:力学性能、起重量、应力及材料
- 2022年人民交通出版社股份有限公司招聘笔试试题及答案解析
- 班组建设工作体系课件
- 第章交通调查与数据分析课件
- 穆斯林太巴热咳庆念词文
评论
0/150
提交评论