首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
阅读以下预备知识、函数说明和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
41
问题
阅读以下预备知识、函数说明和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://kaotiyun.com/show/B0DZ777K
本试题收录于:
软件设计师下午应用技术考试题库软考中级分类
0
软件设计师下午应用技术考试
软考中级
相关试题推荐
以下叙述中,不正确的是()。
在面向对象分析和设计中,用类图给出系统的静态设计视图,其应用场合不包括___________(45)。下图是一个UMI,类图,其中类University和类School之间是___________(46)关系,类Person和类PersonRecord之间
下图是一个软件项目的活动图,其中顶点表示项目里程碑,连接顶点的边表示包含的活动,则完成该项目的最少时间为_____________(34)天。活动BD最多可以晚开始______________(35)天而不会影响整个项目的进度。(35)
在结构化分析方法中,利用分层数据流图对系统功能建模。以下关于分层数据流图的叙述中,不正确的是___________(32)。采用数据字典为数据流图中的每个数据流、文件、加工以及组成数据流或文件的数据项进行说明,其条目不包括____________(33)。
在面向对象技术中,(43)是一组具有相同结构、相同服务、共同关系和共同语义的(44)集合,其定义包括名称、属性和操作。(43)
在结构化分析方法中,数据流图描述数据在系统中如何被传送或变换,反映系统必须完成的逻辑功能,用于(38)建模。在绘制数据流图时,(39)。(38)
在各种不同的软件需求中,(36)描述了用户使用产品必须要完成的任务,可以用UML建模语言的(37)表示。(36)
若某文件系统的目录结构如下图所示,假设用户要访问文件f1.java,且当前工作目录为Program,则该文件的全文件名为(24),其相对路径为(25)。 (25)
若某文件系统的目录结构如下图所示,假设用户要访问文件f1.java,且当前工作目录为Program,则该文件的全文件名为(24),其相对路径为(25)。 (24)
编译和解释是实现高级程序设计语言的两种方式,其区别主要在于______。
随机试题
在资产负债表中存货跌价准备应作为存货的抵减额在存货项目中列示。()
“十一五”时期发展房地产业应该()。
应急救援专家组在应急准备和应急救援中起着重要的参谋作用,包括对()等行动提出决策性的建议。
在Excel中,要求将所有数值小于60的单元格自动显示成红色的数字。实现这个要求可以使用“格式”菜单中的()命令。
企业如果未经海关许可并且补交应缴税款,擅自将批准进口的来料加工、来件装配的零件、制成品等保税货物在境内销售的,海关将对其处以()。
巴塞尔委员会规定的,以下哪些属于流动性资产?()
为了避免游客丢失物品、证件,导游要随时提醒游客()。
下列选项中,属于行政程序制度的是()。
我国地形特点多样,著名的四大盆地中被称为“聚宝盆”的是:
TheUS$3-millionFundamentalPhysicsPrizeisindeedaninterestingexperiment,asAlexanderPolyakovsaidwhenheacceptedt
最新回复
(
0
)