首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
阅读以下预备知识、函数说明和C代码,将应填入(n)处的字句填写完整。 [说明] (1)对给定的字符集合及相应的权值,采用哈夫曼算法构造最优二叉树,并用结构数组存储最优二叉树。例如,给定字符集合{a,b,c,d)及其权值2、7、4、5,可构造如
阅读以下预备知识、函数说明和C代码,将应填入(n)处的字句填写完整。 [说明] (1)对给定的字符集合及相应的权值,采用哈夫曼算法构造最优二叉树,并用结构数组存储最优二叉树。例如,给定字符集合{a,b,c,d)及其权值2、7、4、5,可构造如
admin
2010-01-15
91
问题
阅读以下预备知识、函数说明和C代码,将应填入(n)处的字句填写完整。
[说明]
(1)对给定的字符集合及相应的权值,采用哈夫曼算法构造最优二叉树,并用结构数组存储最优二叉树。例如,给定字符集合{a,b,c,d)及其权值2、7、4、5,可构造如图3-26所示的最优二叉树,以及相应的结构数组Ht(如表3-12所示,其中数组元素Ht[0]不用)。
结构数组Ht的类型定义如下:
(2)用“0”或“1”标识最优二叉树中分支的规则是:从一个结点进入其左(右)孩子结点,就用“0”(或“1”)标识该分支(示例见图3-26)。
(3)若用上述规则标识最优二叉树的每条分支后,从根结点开始到叶子结点为止,按经过分支的次序将相应标识依次排列,可得到由“0”、“1”组成的一个序列,称此序列为该叶子结点的前缀编码。例如图3-26所示的叶子结点a、b、c、d的前缀编码分别是110、0、111、10。
[函数说明1]
函数void LeafCode (int root,int n)的功能是:采用非递归方法,遍历最优二叉树的全部叶子结点,为所有的叶子结点构造前缀编码。其中,形参root为最优二叉树的根结点下标;形参n为叶子结点个数。
在函数void LeafCode (int root,int n)构造过程中,将Ht[p].weight域用做被遍历结点的遍历状态标志。
[函数4.1]
[函数说明2]
函数void Decode (char (作图)buff,int root)的功能是:将前缀编码序列翻译成叶子结点的字符序列,并输出。其中,形参root为最优二叉树的根结点下标;形参buff指向前缀编码序列。
[函数4.2]
选项
答案
这是一道要求读者在用哈夫曼算法构造的最优二叉树上进行编码和译码的程序设计题。本题的解答思路如下。 哈夫曼算法构造最优二叉树的过程如下。 ①根据给定的n个权值{W1,W2,W3,……Wn)构成n棵二叉树的集合F={T1,T2,T3,……Tn),其中每棵二叉树Ti中只有一个带权为Wi的根结点,其左、右子树均空。 ②在F中选取两棵根结点权值最小的树作为左、右子树构造一棵新的二叉树,且置新的二叉树的根结点的权值为其左、右子树根结点的权值之和。 ③在F中删除这两棵二叉树,同时将新得到的二叉树加入F中。 ④重复步骤②和③,直到F只含一棵树为止。这棵树便是最优二叉树。 综上所述,最优二叉树是从叶子到根构造起来的,每次都是先确定一棵二叉树的左、右子树,然后再构造出树根结点,因此最优二叉树中只有叶子结点和分支数为2的内部结点。若已知叶子的数目为n,则内部结点数比叶子少1,因此整棵树所需的存储空间规模是确定的,可以采用数组空间来存储最优二叉树。 例如,给定字符集合{a,b,c,d)及其权值2、7、4、5,构造最优二叉树的过程如图3-31所示。 由于算法中对构成左、右子树的二叉树不进行限定,因此用哈夫曼算法构造出的最优二叉树的形态不是惟一的。另外,题干中已给出了存放最优二叉树的结构数组Ht的类型定义,以及存储图3-31所构造出的最优二叉树的结构数组Ht(见表3-12)。 [*] 由于二叉树中的结点最多只有两个分支,若用“0”和“1”分别标识最优二叉树中的左子树分支和右子树分支,那么从根结点开始到叶子结点为止,按经过分支的次序将相应标识依次排列,可得到由“0”和“1”组成的一个序列,称此序列为该叶子结点的前缀编码。例如图3-26所示的最优二叉树叶子结点a、 b、c、d的前缀编码分别是110、0、111、10。 当最优二叉树的构造完成后,每个结点的weight域就可挪作他用,在构造哈夫曼编码的过程中,weight域用做被遍历结点的遍历状态标志。从树根出发,以非递归方式遍历最优二叉树的方法是:先沿着树根的左分支向叶子方向搜索,并用code[]记下所经过的分支的标识,同时用cdlen记录结点的路径长度,一直到叶子结点为止,即可得到当前正在访问的叶子的编码。然后,从该叶子结点回退到其父结点F。若刚才是从F的左子树回到F,则下一次应进入F的右子树进行遍历;若是从F的右子树回到F结点,则下一步应继续向F的父结点回退。 由以上分析可知,对于结点F,遍历过程中最多可能以3种不同的情况经过该结点,因此要为F结点的weight域赋予不同的值进行标识。初始时weight=0,当沿遍历路径到达该结点时其weight域值等于0,则进入其左子树分支进行遍历,并将weight置为1;若沿遍历路径到达该结点时其weight域值等于1,则说明刚从其左子树返回,下面应进入其右子树进行遍历并将weight置为2;若沿遍历路径到达该结点时其 weight域值等于2,则说明刚从其右子树返回,下面应继续向该结点的父结点回退,并将weight置为0。遍历路线如图3-32中箭头方向所示。 [*] 函数void LeafCode (int root,int n)的功能是:采用非递归方法,遍历最优二叉树的全部叶子结点,为所有的叶子结点构造前缀编码。由于在该函数(1)空缺处之后的语句“strcpy (Hc[p],code);”,是进行字符串的复制运算,则需要对源串中的串结束标志进行设置,因此(1)空缺处所填写的语句是“code[cdlen] =‘\0’”或“code[cdlen]=0”。 (2)空缺处是从右子树向父结点回退的处理,因此该空缺处所填入的内容是“Ht[p].parent”。由于每向上层回退一次,结点的路径长度就会减1,因此(3)空缺处所填写的语句是“--cdlen”或其等价形式。 函数void Decode (char (作图)buff,int root)的功能是:将前缀编码序列翻译成叶子结点的字符序列,并输出。译码的过程是:从根出发,若编码序列的当前字符是“0”,则进入左子树分支,否则进入右子树分支,直到到达一个叶子结点时为止,此时叶子所表示的字符就是翻译出的字符。若编码序列还没有结束,则重新从树根出发,重复上述过程,直到将编码序列结束。所以(4)空缺处所填写的语句是“(作图)buff==‘0’”或其等价形式。 由于到达一个叶子结点时,超前读入了一个编码序列中的字符,因此(5)空缺处所填写的语句是“buff--”或其等价形式。
解析
转载请注明原文地址:https://www.kaotiyun.com/show/B0DZ777K
本试题收录于:
软件设计师下午应用技术考试题库软考中级分类
0
软件设计师下午应用技术考试
软考中级
相关试题推荐
以下属于影响软件可靠性因素的是()。①软件运行剖面②软件规模③软件内部结构④软件的开发方法和开发环境⑤软件的可靠性投入
在面向对象分析和设计中,用类图给出系统的静态设计视图,其应用场合不包括___________(45)。下图是一个UMI,类图,其中类University和类School之间是___________(46)关系,类Person和类PersonRecord之间
堆是一种数据结构,分为大顶堆和小顶堆两种类型。大(小)顶堆要求父元素大于等于(小于等于)其左右孩子元素。则___________(41)是一个大项堆结构,该堆结构用二叉树表示,其高度(或层数)为___________(42)。(42)
对于逻辑表达式((bl&b2)||in),需要_______个测试用例才能完成条件组合覆盖。
下面关于程序语言的叙述,错误的是(22)。
假设系统中有三类互斥资源R1、R2和R3,可用资源数分别为10、5和3。在T0时刻系统中有P1、P2、P3、P4和P5五个进程,这些进程对资源的最大需求量和已分配资源数如下表所示,此时系统剩余的可用资源数分别为(22)。如果进程按(23)序列执行,那么系统
在数据库逻辑结构设计阶段,需要(20)阶段形成的(21)作为设计依据。(20)
在以阶段划分的编译器中,符号表管理和()贯穿于编译器工作始终。
对某商店业务处理系统采用数据流图(DFD)进行功能建模,其中“检查订货单”是其中的一个①。由于在进行订货单检查时,需要根据客户的欠款情况、订单金额等多个条件判断是否采取发出催款单、准备货物、发出发货单等行为,此时适合采用②进行描述。②处
某软件项目的活动图如下图所示,其中顶点表示项目里程碑,连接顶点的边表示包含的活动,边上的数字表示活动的持续时间(天)。活动EH最多可以晚开始①天而不影响项目的进度。由于某种原因,现在需要同一个工作人员完成BC和BD,则完成该项目的最少时间为②天
随机试题
骨髓象必须与血象结合分析是因为不同疾病的
背景材料:某化工生产设备安装工程项目,采用解体安装方法进行施工。某机电安装工程公司通过投标取得该项目的总承包施工任务。为了控制分包商的施工质量,业主分别与总承包方和分分包方签订了工程施工总承包合同和分包合同。在合同履行过程中发生了以下事件。事件1:该机电
财政部门对各单位实施监督的事项主要包括()。
根据公司治理的基本原则,下列各项中,说法错误的是()。
材料:某初中历史教师刘某为新课“中华文化的勃兴(一)”准备教学设计。他的教学设计流程大体如下:首先,教师通过一段经过剪辑整理的视频课件,介绍先秦时期的文字演变和当时人们对天文现象的记录,以此作为整节课的内容导入。其次,教师在学
《新元史》记载:“上至中书省,下逮郡县,亲民之吏,必以蒙古人为长,汉人南人贰之。”此处的“汉人”指的是()。
曾经,在央视“3·15”晚会之后,“饿了么”在全国下线几千家商铺。不过,被下线的“黑店”多数并未消失,而是转战美团外卖和百度外卖,有的甚至重回“饿了么”。现如今,这些无证无照、卫生堪忧的黑心作坊仍在我们身边,且越来越嚣张。似曾相识的不只是这些黑心
地震短期、临震预报仍是世界性难题,目前,精确预测地震的震级和时间还无法做到。国外地震学家普遍认为,地壳下层的塑性岩石或蛇纹岩被挤进地壳上层的裂缝中时,就会引发地震。这些容易滑动的蛇纹岩是由富含铁、镁的矿物与水作用而生成的,在此过程中会产生氢气。一旦该层发生
简述新闻评论的基本类型。(中国传媒大学,2009年)
1912年1月1日,孙中山在南京宣誓就职,改国号为中华民国,定1912年为民国元年,并成立中华民国临时政府。南京临时政府是一个资产阶级共和国性质的革命政权()
最新回复
(
0
)