《数据结构答案第5章.docx》由会员分享,可在线阅读,更多相关《数据结构答案第5章.docx(17页珍藏版)》请在三一办公上搜索。
1、第5章树和二叉树1970-01-01第5章树和二叉树课后习题讲解1.填空题树是n (n0)结点的有限集合,在一棵非空树中,有()个根结点,其余的结点分成m (m0)个()的集合,每个集合都是根结点的子树。【解答】有且仅有一个,互不相交树中某结点的子树的个数称为该结点的(),子树的根结点称为该结点的(),该结点称为其子树根 结点的()。【解答】度,孩子,双亲一棵二叉树的第i(i1)层最多有()个结点;一棵有n(n0)个结点的满二叉树共有()个叶子 结点和()个非终端结点。【解答】2i-1,(n+1)/2, (n-1)/2【分析】设满二叉树中叶子结点的个数为n0,度为2的结点个数为n2,由于满二叉
2、树中不存在度为1的 结点,所以 n=n0+n2;由二叉树的性质 n0=n2+1,得 n0=(n+1)/2, n2=(n-1)/2。 设高度为h的二叉树上只有度为0和度为2的结点,该二叉树的结点数可能达到的最大值是(),最 小值是()。【解答】2h -1,2h-1【分析】最小结点个数的情况是第1层有1个结点,其他层上都只有2个结点。深度为k的二叉树中,所含叶子的个数最多为()。【解答】2k-1【分析】在满二叉树中叶子结点的个数达到最多。具有100个结点的完全二叉树的叶子结点数为()。【解答】50【分析】100个结点的完全二叉树中最后一个结点的编号为100,其双亲即最后一个分支结点的编号为50,
3、也就是说,从编号51开始均为叶子。巳知一棵度为3的树有2个度为1的结点,3个度为2的结点,4个度为3的结点。则该树中有() 个叶子结点。【解答】12【分析】根据二叉树性质3的证明过程,有n0=n2+2n3+1(n0、n2、n3分别为叶子结点、度为2的结点 和度为3的结点的个数)。某二叉树的前序遍历序列是ABCDEFG,中序遍历序列是CBDAFGE,则其后序遍历序列是()。【解答】CDBGFEA【分析】根据前序遍历序列和后序遍历序列将该二叉树构造出来。在具有n个结点的二叉链表中,共有()个指针域,其中()个指针域用于指向其左右孩子,剩下的 ()个指针域则是空的。【解答】2n,n-1,n+1 在有
4、n个叶子的哈夫曼树中,叶子结点总数为(),分支结点总数为()。【解答】n,n-1【分析】n-1个分支结点是经过n-1次合并后得到的。2.选择题如果结点A有3个兄弟,B是A的双亲,则结点B的度是()。A 1 B 2 C 3 D 4【解答】D设二叉树有n个结点,则其深度为()。A n-1 B n C 却+1 D不能确定【解答】D!1口射圳【分析】此题并没有指明是完全二叉树,则其深度最多是n,最少是l白 J +1。二叉树的前序序列和后序序列正好相反,则该二叉树一定是()的二叉树。A空或只有一个结点B高度等于其结点数C任一结点无左孩子D任一结点无右孩子【解答】B【分析】此题注意是序列正好相反,则左斜树
5、和右斜树均满足条件。线索二叉树中某结点R没有左孩子的充要条件是()。A R.lchild=NULL B R.ltag=0 C R.ltag=1 D R.rchild=NULL【解答】C【分析】线索二叉树中某结点是否有左孩子,不能通过左指针域是否为空来判断,而要判断左标志是否为1。深度为k的完全二叉树至少有()个结点,至多有()个结点,具有n个结点的完全二叉树按层序从 1开始编号,则编号最小的叶子的序号是()。A 2k-2+1 B 2k-1 C 2k -1 D 2k-1 -1E 2k+1 F 2k+1 -1 G 2k -1+1 H 2k【解答】B,C,A【分析】深度为k的完全二叉树最少结点数的情
6、况应是第k层上只有1个结点,最多的情况是满二叉树, 编号最小的叶子应该是在结点数最少的情况下,叶子结点的编号。一个高度为h的满二叉树共有n个结点,其中有m个叶子结点,则有()成立。A n=h+m B h+m=2n C m=h-1 D n=2m-1【解答】D【分析】满二叉树中没有度为1的结点,所以有m个叶子结点,则度为2的结点个数为m-1。任何一棵二叉树的叶子结点在前序、中序、后序遍历序列中的相对次序()。A肯定不发生改变B肯定发生改变C不能确定D有时发生变化【解答】A【分析】三种遍历次序均是先左子树后右子树。如果T是由有序树T转换而来的二叉树,那么T中结点的前序序列就是T中结点的()序列,T中
7、 结点的后序序列就是T中结点的( )序列。A前序B中序C后序D层序【解答】A,B设森林中有4棵树,树中结点的个数依次为n1、n2、n3、n4,则把森林转换成二叉树后,其根结点的 右子树上有()个结点,根结点的左子树上有()个结点。A n1-1 B n1 C n1+n2+n3 D n2+n3+n4【解答】D,A【分析】由森林转换的二叉树中,根结点即为第一棵树的根结点,根结点的左子树是由第一棵树中除了根 结点以外其余结点组成的,根结点的右子树是由森林中除第一棵树外其他树转换来的。(10)讨论树、森林和二叉树的关系,目的是为了()。A借助二叉树上的运算方法去实现对树的一些运算B将树、森林按二叉树的存
8、储方式进行存储并利用二叉树的算法解决树的有关问题C将树、森林转换成二叉树D体现一种技巧,没有什么实际意义【解答】B3.判断题在线索二叉树中,任一结点均有指向其前趋和后继的线索。【解答】错。某结点是否有前驱或后继的线索,取决于该结点的标志域是否为1。在二叉树的前序遍历序列中,任意一个结点均处在其子女的前面。【解答】对。由前序遍历的操作定义可知。二叉树是度为2的树。【解答】错。二叉树和树是两种不同的树结构,例如,左斜树是一棵二叉树,但它的度为1。由树转换成二叉树,其根结点的右子树总是空的。【解答】对。因为根结点无兄弟结点。用一维数组存储二叉树时,总是以前序遍历存储结点。【解答】错。二叉树的顺序存储
9、结构是按层序存储的,一般适合存储完全二叉树。4. 证明:对任一满二叉树,其分枝数B=2(n0-1)。(其中,n0为终端结点数)【解答】因为在满二叉树中没有度为1的结点,所以有:n=n0+n2设B为树中分枝数,则n=B+1所以B=n0 +n2-1再由二叉树性质:n0=n2+1代入上式有:B=n0+n0-1-1=2(n0-1)5. 证明:巳知一棵二叉树的前序序列和中序序列,则可唯一确定该二叉树。【解答】证明采用归纳法。设二叉树的前序遍历序列为a1a2a3“. an,中序遍历序列为b1b2b3“. bn。当n=1时,前序遍历序列为al,中序遍历序列为bl,二叉树只有一个根结点,所以,a1= bl,可
10、以唯一 确定该二叉树;假设当nrchild coutfoat-data;PreOrder (foot-lchild)rPreOrd-er (root-rchild); 设计算法求二叉树的深度。【解答】当二叉树为空时,深度为0;若二叉树不为空,深度应是其左右子树深度的最大值加1,而其左右 子树深度的求解又可通过递归调用本算法来完成。具体算法如下:求二又树深废算法DepthmtDfpth(biNode *root)if-f !root) return 0, dse hl= D epth (roat-l-chLld);hr= D epth (root -.rchild)-.; return. maz
11、 (hl, hr)十 i;编写算法,要求输出二叉树后序遍历序列的逆序。【解答】要想得到后序的逆序,只要按照后序遍历相反的顺序即可,即先访问根结点,再遍历根结点的右 子树,最后遍历根结点的左子树。注意和前序遍历的区别,具体算法如下:后序的逆序遍长算法PastQriervoid PostOrderfBiNode *roo0if (ro ot) (cout: data;PostOrder (ro ot-rchildO PostOrdef (ro ot-ichild)、, 以二叉链表为存储结构,编写算法求二叉树中结点x的双亲。【解答】对二叉链表进行遍历,在遍历的过程中查找结点x并记载其双亲。具体算法如
12、下:查找某融点的誉亲算法ParentBjMod e- Parent (BiNode, ro ot, T xj标是全局量初值沏空if (rciot);fif (rmt专?由均=顼 return p;else (p=raot,Parent Croot- lchild;1 x),Parent Cr o ot- rcliild., k);:以二叉链表为存储结构,在二叉树中删除以值x为根结点的子树。【解答】对二叉链表进行遍历,在遍历的过程中查找结点x并记载其双亲,然后将结点x的双亲结点中指 向结点x的指针置空。具体算法如下:册1除结点W算法Deletevoid Delete (BiNoie root?
13、T x) /p 是全局垦,初请为空if (root) if (root-data=z)if (!py.root=NULL;else if (plcliild= =root) p=lchild=NULL;elsh:rthild=NULL,赤&p=raotD eiet etro otlcliil d,芝),D eiet e Cr o otr rchild,岌2一棵具有n个结点的二叉树采用顺序存储结构,编写算法对该二叉树进行前序遍历。【解答】按照题目要求,设置一个工作栈以完成对该树的非递归算法,思路如下: 每访问一个结点,将此结点压栈,查看此结点是否有左子树,若有,访问左子树,重复执行该过程直到 左
14、子树为空。 从栈弹出一个结点,如果此结点有右子树,访问右子树执行步骤,否则重复执行步骤。 具体算法如下:顺序存储的前序凝蜃算法Exchangetemplate clasyoid PreOrdci(T A , int n)topt; /贱初始化.采用服序栈并腾定不金发生溢出 i=l; cau.t.Ai;印+十切司=4;爨while (top!1)while Cj=nJcouRTNode Search (TNode 登*, T 瓦 int i).;ifp=root-fir5tcliild;:赢k S仁NULL & 河j+;p=p_、口 ghtwib:.if .(p)return p;else re
15、turn NULL;Search (rootJfrstGhild;-k; i);S ear ch (r ot /rightsiti ? i);学习自测及答案1 .前序遍历和中序遍历结果相同的二叉树是()。A根结点无左孩子的二叉树B根结点无右孩子的二叉树C所有结点只有左子树的二叉树D所有结点只有右子树的二叉树【解答】D1. 前序遍历和中序遍历结果相同的二叉树是()。A根结点无左孩子的二叉树B根结点无右孩子的二 叉树C所有结点只有左子树的二叉树D所有结点只有右子树的二叉树【解答】D2. 由权值为3, 8, 6, 2, 5的叶子结点生成一棵哈夫曼树,其带权路径长度为()。A 24 B 48 C 53
16、 D 72【解答】C3. 用顺序存储的方法将完全二叉树中的所有结点逐层存放在数组A1 An中,结点Ai若有左子树, 则左子树的根结点是()。A A2i-1 B A2i+1 C Ai/2 D A2i【解答】D4. 对任何一棵二叉树T,如果其终端结点的个数为n0,度为2的结点个数为n2,则()。A n0=n2-1 B n0=n2 C n0=n2+1 D 没有规律【解答】C5. 一棵满二叉树中共有n个结点,其中有m个叶子结点,深度为h,则()。A n=h+m B h+m=2n C m=h-1 D n=2h-1【解答】D6. 对于完全二叉树中的任一结点,若其右分支下的子孙的最大层次为h,则其左分支下的
17、子孙的最大层次 为()。A h B h+1 C h 或 h+1 D 任意【解答】C7. 假定一棵度为3的树中结点数为50,则其最小高度应为。A 3 B 4 C 5 D 6【解答】C8. 在线索二叉树中,一个结点是叶子结点的充要条件为()。A左线索标志为0,右线索标志为1 B左线索标志为1,右线索标志为0C左、右线索标志均为0 D左、右线索标志均为1【解答】C9. 对于一棵具有n个结点的树,其所有结点的度之和为()。【解答】n-110. 在顺序存储的二叉树中,编号为i和j的两个结点处在同一层的条件是()。【解答】岫小屁掐11. 现有按前序遍历二叉树的结果ABC,问有哪几种不同的二叉树可以得到这一
18、结果? 【解答】共有5种二叉树可以得到这一结果,如图5-15所示。15前序序列为垂U的二灵树12. 试找出分别满足下列条件的所有二叉树: 前序序列和中序序列相同。中序序列和后序序列相同。 前序序列和后序序列相同。【解答】空二叉树、只有一个根结点的二叉树和右斜树。空二叉树、只有一个根结点的二叉树和左斜树。 空二叉树、只有一个根结点的二叉树13. 将下面图5-16所示的树转换为二叉树,图5-17所示的二叉树转换为树或森林。【解答】图5-16所示树转换的二叉树如图5-18所示,图5-17所示二叉树转换的森林如图5-19所示。14. 以孩子兄弟表示法作为存储结构,编写算法求树的深度。【解答】采用递归算
19、法实现。若树为空树,则其深度为0,否则其深度等于第一棵子树的深度+1和兄弟子 树的深度中的较大者。具体算法如下:太树的深度算法DepthintDepth(TNode 岫成:if Qroot) return 0;else (h 1 =D 即 th (f.o ot-firstchildl: h2= D ep th面h 以return aias (h 1+1hZ);15. 设计算法,判断一棵二叉树是否为完全二叉树。【解答】根据完全二叉树的定义可知,对完全二叉树按照从上到下、从左到右的次序(即层序)遍历应该 满足:若某结点没有左孩子,则其一定没有右孩子;若某结点无右孩子,则其所有后继结点一定无孩子。若
20、有一结点不满足其中任意一条,则该二叉树就一定不是完全二叉树。因此可采用按层次遍历二叉树的方 法依次对每个结点进行判断是否满足上述两个条件。为此,需设两个标志变量BJ和CM,其中BJ表示巳扫 描过的结点是否均有左右孩子,CM存放局部判断结果及最后的结果。具体算法如下:判断克全二会树算法ComBiTree bool ComB :Yee (BiNode.*root)廿口址cai1,秋列初始化.采用顺序队列并假定不会发生溢出 BJ=l,把 M=l;if-(root)-: -Q j-+rear=rootwhile (frontierearlp=Q+frant;if匚hi!。;.矿BJ=0;if (p-rchild) CM=0,else.fQ +rear=p-Hchild;dse Q -I-+front =p-rchild;return CM;关闭