课程设计报告1.doc

上传人:叶*** 文档编号:35244495 上传时间:2022-08-20 格式:DOC 页数:4 大小:20KB
返回 下载 相关 举报
课程设计报告1.doc_第1页
第1页 / 共4页
课程设计报告1.doc_第2页
第2页 / 共4页
点击查看更多>>
资源描述

《课程设计报告1.doc》由会员分享,可在线阅读,更多相关《课程设计报告1.doc(4页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、合肥学院计算机科学与技术系课程设计报告20212021学年第二学期课程数据构造与算法课程设计名称哈弗曼算法专业班级12级软件工程指导教师李红2021年9月题目:设计程序以实现构造哈夫曼树的哈夫曼算法。要求:求解所构造的哈夫曼树的带全路径长度。一、问题分析和任务定义根据要求需要:1、规划哈夫曼树的数据类型; 2、完成对哈夫曼树的输入; 3、构造出哈夫曼树; 4、求出哈夫曼树的带权路径长度; 5、输出哈夫曼树的结点信息。二、数据构造的选择和概要设计数据构造的选择:1. 由于一棵有n个叶子结点的哈夫曼树上共有2n-1个结点,可以采用为2n-1的数组顺序存储结点信息。每个结点包括四个域:一个float

2、类型的weight用来存储每个叶子结点的权值,三个int 类型的parent,rchild,lchild用来表示结点的父节点和左右孩子;结点的类型描述为:typedef struct float weight;int parent,lchild,rchild;hufm;假设给定n个权值,那么可定义数组tree来存储哈夫曼树上的结点:Hufm tree2n-1;为实现上述功能需要:1. 首先给定n个叶子结点的权值,构造n棵单结点二叉树;2. 在上面的二叉树中选择两个权值最小的结点,分别为左右孩子构造一棵新的二叉树且新的二叉树根结点的权值为其左右子树根结点的权值之和。3. 然后删除掉被选取的两棵二

3、叉树,并将新的二叉树参加。4. 重复2,3两步,直到只剩一颗二叉树为止。5. 由于哈夫曼树的带权路径长度就是等于所有非叶子结点值的和,因为树的带权路径长度是通过将所有叶子结点乘以对应的路径长度之和求出来的,而将所有的非叶子结点的累加过程就是包括了上述的计算,所以直接就可以计算出。三、详细设计和编码 1、程序先输入一个int的n表示共有n个叶子结点,然后输入n个叶子结点的权值;同时将数组内的所有值都初始化为-1; 2、根据概要设计的方法来构造哈夫曼树,将新的父节点放在数组下标为n到2n-2中,所以进展一个外层循环,为确保每次能够找到未含有父结点的权值最小的两个结点,需要定义两个整型的数,smal

4、l1,small2,在每次比拟之前将一个最大值赋给它们,然后进展比拟,在一个内层的循环进展,如果找到一个比small1小的结点,就先把small1赋给small2然后,在将这个结点的权值赋给small1,同时类似的用两个整型的数记录这个结点的下标;然后再每次内层循环完毕后,将这两个叶子结点的parent值改为这个父节点的下标,将父节点的左右孩子域改为两个孩子结点的下标,将父节点的权值weight变成两个孩子的权值之和。 3、定义一个float类型的sum,初始化为0,然后在每次产生新结点的权值时,就将其累加,其为哈夫曼树的带权路径长度。 4、最后将构造好的哈夫曼树输出在屏幕上,并且输出带权路径

5、长度。四、上机调试过程开场由于没有想到求带权路径长度可以通过上述方法进展,所有还需要在树建好以后进展每个叶子结点求其路径长度,这大大的增加了程序的时间复杂性,最后将其改良。五、测试结果及其分析程序的一开场是将构造体中的元素都初始化为0,但是由于为了更加清晰的表示出构造哈弗曼树的各个结点关系,防止与数组下标为0的进展混淆,将其初始化为-1。图中清晰的表示出了各个结点的信息,其中数组下标为0n的为叶子结点,其lchild与rchild都是-1;weight记录各个结点的权值,parent中的数字为每个结点的父节点所在的元素下标,lchild与rchild分别为其左右孩子的下标。六、用户使用说明 根

6、据屏幕中的提示,先输入叶子结点的个数,然后输入n个叶子结点的权值,其可以为实数,然后回车就可以看到结果了。七、参考文献1 王昆仑,李红. 数据构造与算法. 北京:中国铁道出版社,2006年5月。2 其它。八、附录#include stdio.htypedef 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(请输

7、入叶子节点的个数);scanf(%d,&n);for(i=0;i2*n-1;i+)treei.parent=-1;treei.lchild=-1;treei.rchild=-1;puts(请输入哈夫曼树的权值);for(i=0;in;i+)scanf(%f,&treei.weight);for(i=n;i2*n-1;i+)p1=p2=0;small1=small2=max;for(j=0;j=i-1;j+)if(treej.parent=-1) if(treej.weightsmall1) small2=small1; small1=treej.weight; p2=p1;p1=j; else

8、 if(treej.weightsmall2) 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;i2*n-1;i+)printf(%d %4.2f %3d %3d %3dn,i,treei.weight,treei.parent,treei.lchild,treei.rchild);printf(构造的哈夫曼树的带权路径长度为:%.2fn,sum);return 0;

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 高中资料

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁