电脑桌面
添加小米粒文库到电脑桌面
安装后可以在桌面快捷访问

算法实验2哈夫曼编码实验报告VIP免费

算法实验2哈夫曼编码实验报告_第1页
1/6
算法实验2哈夫曼编码实验报告_第2页
2/6
算法实验2哈夫曼编码实验报告_第3页
3/6
-1 - 昆明理工大学信息工程与自动化学院学生实验报告 ( 2011 — 2012 学年 第 1 学期 ) 课程名称:算法设计与分析 开课实验室:信自楼机房 444 2011 年 11 月 02 日 年级、专业、班 学号 姓名 成绩 实验项目名称 哈夫曼编码 指导教师 教师评语 该同学是否了解实验原理: A.了解□ B.基本了解□ C.不了解□ 该同学的实验能力: A.强 □ B.中等 □ C.差 □ 该同学的实验是否达到要求: A.达到□ B.基本达到□ C.未达到□ 实验报告是否规范: A.规范□ B.基本规范□ C.不规范□ 实验过程是否详细记录: A.详细□ B.一般 □ C.没有 □ 教师签名: 年 月 日 一、上机目的及内容 上机目的 (1)了解前缀编码的概念,理解数据压缩的基本方法; (2)掌握最优子结构性质的证明方法; (3)掌握贪心法的设计思想并能熟练运用。 上机内容 设需要编码的字符集为{d1, d2, …, dn},它们出现的频率为{w1, w2, …, wn},应用哈夫曼树构造最短的不等长编码方案。 二、实验原理及基本技术路线图(方框原理图或程序流程图) 实验原理 (1)证明哈夫曼树满足最优子结构性质; (2)设计贪心算法求解哈夫曼编码方案; (3)设计测试数据,写出程序文档 。 -2 - 流程图 开始建立huffman 树初始化parent ,lchild ,rchild 为-1从所有树中选择权值最小的两棵对变量 small1 和small2 赋值(森林中得任意两棵树的权值)Huffmantree[i].weightsmall2否交换 small1 和small2将两棵树合并,生成新节点为前 n个元素编码双亲节点是否为空否该节点为左孩子是A[i]=0;i=i+1A[i]=1;i=i+1否i=n是结束是否 -3- 三、所用仪器、材料(设备名称、型号、规格等或使用软件) 设备:1 台 PC 及 VISUAL C++6.0 软件。 四、实验方法、步骤(或:程序代码或操作过程) 源程序 #include #define n 7 //一共有 n 棵左右孩子均为空的树 #define m 2*n-1 //生成哈夫曼树后共有 2*n-1 个节点 float small1,small2; int flag1,flag2,count; typedef struct HuffmanTree { float weight; int lchild,rchild,parent; }huffman; huffman huffmantree[m]; void CreatHuffmanTree() { int i; void select(); printf("请输入%d 棵树的权值:",n); //初始化每棵树的权值 for(i=0...

1、当您付费下载文档后,您只拥有了使用权限,并不意味着购买了版权,文档只能用于自身使用,不得用于其他商业用途(如 [转卖]进行直接盈利或[编辑后售卖]进行间接盈利)。
2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。
3、如文档内容存在违规,或者侵犯商业秘密、侵犯著作权等,请点击“违规举报”。

碎片内容

算法实验2哈夫曼编码实验报告

确认删除?
VIP
微信客服
  • 扫码咨询
会员Q群
  • 会员专属群点击这里加入QQ群
客服邮箱
回到顶部