数据结构习题题目及答案_树和二叉树_参考答案.doc

数据结构习题题目及答案_树和二叉树_参考答案.doc

  1. 1、本文档共31页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构习题题目及答案_树和二叉树_参考答案

一、基础知识题666666666666666666666666666 6.1设树T的度为4,其中度为1,2,3和4的结点个数分别为4,2,1,1,求树T中的叶子数。 【解答】 设度为m的树中度为0,1,2,…,m的结点数分别为n0, n1, n2,…, nm,结点总数为n,分枝数为B,则下面二式成立 n= n0+n1+n2+…+nm?????????????? ?????(1) n=B+1= n1+2n2?+…+mnm+1??? ?????????(2) 由(1)和(2)得叶子结点数n0=1+ ????? 即: n0=1+(1-1)*4+(2-1)*2+(3-1)*1+(4-1)*1=8 ? 6.2一棵完全二叉树上有1001个结点,求叶子结点的个数。 【解答】因为在任意二叉树中度为2 的结点数n2和叶子结点数n0有如下关系:n2=n0-1,所以设二叉树的结点数为n, 度为1的结点数为n1,则 ???????????? n= n0+ n1+ n2 ???????????? n=2n0+n1-1 ???????????? 1002=2n0+n1 由于在完全二叉树中,度为1的结点数n1至多为1,叶子数n0是整数。本题中度为1的结点数n1只能是0,故叶子结点的个数n0为501. 注:解本题时要使用以上公式,不要先判断完全二叉树高10,前9层是满二叉树,第10层都是叶子,……。虽然解法也对,但步骤多且复杂,极易出错。 ? 6.3 一棵124个叶结点的完全二叉树,最多有多少个结点。 【解答】由公式n=2n0+n1-1,当n1为1时,结点数达到最多248个。 ? 6.4.一棵完全二叉树有500个结点,请问该完全二叉树有多少个叶子结点?有多少个度为1的结点?有多少个度为2的结点?如果完全二叉树有501个结点,结果如何?请写出推导过程。 【解答】由公式n=2n0+n1-1,带入具体数得,500=2n0+n1-1,叶子数是整数,度为1的结点数只能为1,故叶子数为250,度为2的结点数是249。 ?若完全二叉树有501个结点,则叶子数251,度为2的结点数是250,度为1的结点数为0。 ? 6.5?某二叉树有20个叶子结点,有30个结点仅有一个孩子,则该二叉树的总结点数是多少。 【解答】由公式n=2n0+n1-1,得该二叉树的总结点数是69。 ? 6.6 求一棵具有1025个结点的二叉树的高h。 【解答】该二叉树最高为1025(只有一个叶子结点),最低高为11。因为2101,故1025个结点的二叉树最低高为11。 ? 6.7 一棵二叉树高度为h,所有结点的度或为0,或为2,则这棵二叉树最少有多少结点。 ?【解答】第一层只一个根结点,其余各层都两个结点,这棵二叉树最少结点数是2h-1。 ? 6.8将有关二叉树的概念推广到三叉树,则一棵有244个结点的完全三叉树的高度是多少。 【解答】设含n个结点的完全三叉树的高度为h,则有 n≤ n≤ 2n??????????? 本题n=244, 故h=6。 ? 6.9 对二叉树的结点从1开始进行连续编号,要求每个结点的编号大于其左、右孩子的编号,同一结点的左、右孩子中,其左孩子的编号小于其右孩子的编号,是采用何种次序的遍历实现编号的。 ?【解答】后序遍历二叉树,因为后序遍历顺序为左子树-右子树-根结点。 ? 6.10 高度为h(h0)的满二叉树对应的森林由多少棵树构成。 ?【解答】因为在二叉树转换为森林时,二叉树的根结点,根结点的右子女,右子女的右子女,……,都是树的根,所以,高度为h(h0)的满二叉树对应的森林由h棵树构成。 ? 6.11 某二叉树结点的中序序列为BDAECF,后序序列为DBEFCA,则该二叉树对应的森林包括几棵树? 【解答】3棵树。(本题不需画出完整的二叉树,更不需要画出森林,只需画出二叉树的右子树就可求解。如上题所述,二叉树的根结点,根结点的右子女,右子女的右子女,……,在二叉树转为森林时,都是树的根。) ? 6.12 对任意一棵树,设它有n个结点,这n个结点的度数之和为多少? ?【解答】n-1。度数其实就是分支个数。根结点无分支所指,其余结点有且只有一个分支所指。 ? 6.13 一棵左子树为空的二叉树在先序线索化后,其中空的链域的个数是多少? 【解答】对二叉树线索化时,只有空链域才可加线索。一棵左子树为空的二叉树在先序线索化时,根结点的左链为空,应加上指向前驱的线索,但根结点无前驱,故该链域为空。同样分析知道最后遍历的结点的右链域为空。故一棵左子树为空的二叉树在先序线索化后,其中空的链域的个数是2个。 ? 6.14 一棵左、右子树均不空的二叉树在先序线索化后,其中空的链域的个数是多少? 【解答】1个。 ? 6.15 设B是由森林F变换得的二叉树。若F中有n个非终端结点

文档评论(0)

haocen + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档