欢迎来到三一文库! | 帮助中心 三一文库31doc.com 一个上传文档投稿赚钱的网站
三一文库
全部分类
  • 研究报告>
  • 工作总结>
  • 合同范本>
  • 心得体会>
  • 工作报告>
  • 党团相关>
  • 幼儿/小学教育>
  • 高等教育>
  • 经济/贸易/财会>
  • 建筑/环境>
  • 金融/证券>
  • 医学/心理学>
  • ImageVerifierCode 换一换
    首页 三一文库 > 资源分类 > DOC文档下载  

    精品资料(2021-2022年收藏)课程设计报告.doc

    • 资源ID:14903412       资源大小:64KB        全文页数:6页
    • 资源格式: DOC        下载积分:4
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录   微博登录  
    二维码
    微信扫一扫登录
    下载资源需要4
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    精品资料(2021-2022年收藏)课程设计报告.doc

    合肥学院计算机科学与技术系课程设计报告20132014学年第二学期课程数据结构与算法课程设计名称哈弗曼算法专业班级12级软件工程指导教师李红2014年9月题目:设计程序以实现构造哈夫曼树的哈夫曼算法。要求:求解所构造的哈夫曼树的带全路径长度。一、问题分析和任务定义根据要求需要:1、规划哈夫曼树的数据类型; 2、完成对哈夫曼树的输入; 3、构造出哈夫曼树; 4、求出哈夫曼树的带权路径长度; 5、输出哈夫曼树的结点信息。二、数据结构的选择和概要设计数据结构的选择:1. 由于一棵有n个叶子结点的哈夫曼树上共有2n-1个结点,可以采用为2n-1的数组顺序存储结点信息。每个结点包括四个域:一个float类型的weight用来存储每个叶子结点的权值,三个int 类型的parent,rchild,lchild用来表示结点的父节点和左右孩子;结点的类型描述为:typedef struct float weight;int parent,lchild,rchild;hufm;若给定n个权值,则可定义数组tree来存储哈夫曼树上的结点:Hufm tree2n-1;为实现上述功能需要:1. 首先给定n个叶子结点的权值,构造n棵单结点二叉树;2. 在上面的二叉树中选择两个权值最小的结点,分别为左右孩子构造一棵新的二叉树且新的二叉树根结点的权值为其左右子树根结点的权值之和。3. 然后删除掉被选取的两棵二叉树,并将新的二叉树加入。4. 重复2,3两步,直到只剩一颗二叉树为止。5. 由于哈夫曼树的带权路径长度就是等于所有非叶子结点值的和,因为树的带权路径长度是通过将所有叶子结点乘以对应的路径长度之和求出来的,而将所有的非叶子结点的累加过程就是包括了上述的计算,所以直接就可以计算出。三、详细设计和编码 1、程序先输入一个int的n表示共有n个叶子结点,然后输入n个叶子结点的权值;同时将数组内的所有值都初始化为-1; 2、根据概要设计的方法来构造哈夫曼树,将新的父节点放在数组下标为n到2n-2中,所以进行一个外层循环,为确保每次能够找到未含有父结点的权值最小的两个结点,需要定义两个整型的数,small1,small2,在每次比较之前将一个最大值赋给它们,然后进行比较,在一个内层的循环进行,如果找到一个比small1小的结点,就先把small1赋给small2然后,在将这个结点的权值赋给small1,同时类似的用两个整型的数记录这个结点的下标;然后再每次内层循环结束后,将这两个叶子结点的parent值改为这个父节点的下标,将父节点的左右孩子域改为两个孩子结点的下标,将父节点的权值weight变成两个孩子的权值之和。 3、定义一个float类型的sum,初始化为0,然后在每次产生新结点的权值时,就将其累加,其为哈夫曼树的带权路径长度。 4、最后将构造好的哈夫曼树输出在屏幕上,并且输出带权路径长度。四、上机调试过程开始由于没有想到求带权路径长度可以通过上述方法进行,所有还需要在树建好以后进行每个叶子结点求其路径长度,这大大的增加了程序的时间复杂性,最后将其改进。五、测试结果及其分析程序的一开始是将结构体中的元素都初始化为0,但是由于为了更加清晰的表示出构造哈弗曼树的各个结点关系,防止与数组下标为0的进行混淆,将其初始化为-1。图中清晰的表示出了各个结点的信息,其中数组下标为0n的为叶子结点,其lchild与rchild都是-1;weight记录各个结点的权值,parent中的数字为每个结点的父节点所在的元素下标,lchild与rchild分别为其左右孩子的下标。六、用户使用说明 根据屏幕中的提示,先输入叶子结点的个数,然后输入n个叶子结点的权值,其可以为实数,然后回车就可以看到结果了。七、参考文献1 王昆仑,李红. 数据结构与算法. 北京:中国铁道出版社,2006年5月。2 其它。八、附录#include "stdio.h"#define max 100.0typedef struct float weight;int parent,lchild,rchild;hufm;int main()/p1,p2分别记录相加后节点的两个孩子的位置int n,i,j,p1,p2;float sum=0;hufm tree100;float small1,small2;/用于得到parent为0的两个最小的puts("请输入叶子节点的个数");scanf("%d",&n);for(i=0;i<2*n-1;i+)treei.parent=-1;treei.lchild=-1;treei.rchild=-1;puts("请输入哈夫曼树的权值");for(i=0;i<n;i+)scanf("%f",&treei.weight);for(i=n;i<2*n-1;i+)p1=p2=0;small1=small2=max;for(j=0;j<=i-1;j+)if(treej.parent=-1) if(treej.weight<small1) small2=small1; small1=treej.weight; p2=p1;p1=j; else if(treej.weight<small2) small2=treej.weight; p2=j; treep1.parent=treep2.parent=i; treei.weight=treep1.weight+treep2.weight; sum+=treei.weight;/求树的带权路径长度 treei.lchild=p1; treei.rchild=p2;printf("输出该哈夫曼树的各个结点的值为:n");printf(" weight parent lchild rchildn");for(i=0;i<2*n-1;i+)printf("%d %4.2f %3d %3d %3dn",i,treei.weight,treei.parent,treei.lchild,treei.rchild);printf("构造的哈夫曼树的带权路径长度为:%.2fn",sum);return 0;

    注意事项

    本文(精品资料(2021-2022年收藏)课程设计报告.doc)为本站会员(时光煮雨)主动上传,三一文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一文库(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    经营许可证编号:宁ICP备18001539号-1

    三一文库
    收起
    展开