第六章_树和二叉树1

上传人:壹****1 文档编号:26976755 上传时间:2018-01-04 格式:DOC 页数:11 大小:45KB
返回 下载 相关 举报
第六章_树和二叉树1_第1页
第1页 / 共11页
第六章_树和二叉树1_第2页
第2页 / 共11页
第六章_树和二叉树1_第3页
第3页 / 共11页
第六章_树和二叉树1_第4页
第4页 / 共11页
第六章_树和二叉树1_第5页
第5页 / 共11页
点击查看更多>>
资源描述

《第六章_树和二叉树1》由会员分享,可在线阅读,更多相关《第六章_树和二叉树1(11页珍藏版)》请在金锄头文库上搜索。

1、第六章 树和二叉树一、选择题1.在线索化二叉树中,t 所指结点没有左子树的充要条件是( )(A)t-left=NULL (B )t-ltag=1(C)t-ltag=1 且 t-left=NULL (D)以上都不对2.二叉树按某种顺序线索化后,任一结点均有指向其前趋和后继的线索,这种说法(A)正确 (B)错误 (C)不同情况下答案不确定3.二叉树的前序遍历序列中,任意一个结点均处在其子女结点的前面,这种说法( )(A)正确 (B)错误 (C)不同情况下答案不确定4.由于二叉树中每个结点的度最大为 2,所以二叉树是一种特殊的树,这种说法( )(A)正确 (B)错误 (C)不同情况下答案不确定5.设

2、高度为 h 的二叉树上只有度为 0 和度为 2 的结点,则此类二叉树中所包含的结点数至少为( ) 。(A)2 h (B)2h-1(C)2 h+1(D)h+16.已知某二叉树的后序遍历序列是 dabec。中序遍历序列是 debac,它的前序遍历序列是( ) 。(A)acbed ( B)decab (C)deabc (D )cedba7.如果 T2 是由有序树 T 转换而来的二叉树,那么 T 中结点的前序就是 T2 中结点的( )(A)前序(B)中序(C)后序( D)层次序8.某二叉树的前序遍历结点访问顺序是 abdgcefh,中序遍历的结点访问顺序是 dgbaechf,则其后序遍历的结点访问顺序

3、是( ) 。(A)bdgcefha (B )gdbecfha (C )bdgaechf (D )gdbehfca9.二叉树为二叉排序树的充分必要条件是其任一结点的值均大于其左孩子的值、小于其右孩子的值。这种说法( )(A)正确(B)错误(C)不同情况下答案不确定10.按照二叉树的定义,具有 3 个结点的二叉树有( )种。(A)3(B)4(C)5(D)611.在一非空二叉树的中序遍历序列中,根结点的右边( )(A)只有右子树上的所有结点( B)只有右子树上的部分结点(C)只有左子树上的部分结点(D)只有左子树上的所有结点12.树最适合用来表示( ) 。(A)有序数据元素(B)无序数据元素(C)元

4、素之间具有分支层次关系的数据(D)元素之间无联系的数据13.任何一棵二叉树的叶结点在先序、中序和后序遍历序列中的相对次序( )(A)不发生改变(B)发生改变(C)不能确定 D.以上都不对14.实现任意二叉树的后序遍历的非递归算法而不使用栈结构,最佳方案是二叉树采用( )存储结构。(A)二叉链表(B)广义表存储结构(C)三叉链表(D)顺序存储结构15.对一个满二叉树,m 个树叶 ,n 个结点,深度为 h,则( )(A)n=h+m (B)h+m=2n(C )m=h-1(D )n=2 h-116.如果某二叉树的前序为 stuwv,中序为 uwtvs,那么该二叉树的后序为( )(A)uwvts (B)

5、vwuts (C)wuvts (D)wutsv17.具有五层结点的二叉平衡树至少有( )个结点。(A)10(B)12(C)15(D)17二、判断题 1.二叉树中任何一个结点的度都是 2。 ( )2.由二叉树结点的先根序列和后根序列可以唯一地确定一棵二叉树。 ( )3.一棵哈夫曼树中不存在度为 1 的结点。 ( )4.平衡二叉排序树上任何一个结点的左、右子树的高度之差的绝对值不大于 2( )三、填空题 1.指出树和二叉树的三个主要差别_,_,_。2.从概念上讲,树与二叉树是两种不同的数据结构,将树转化为二叉树的基本目的是_3.若结点 A 有三个兄弟(包括 A 本身), 并且 B 是 A 的双亲结

6、点,B 的度是_4.若一棵具有 n 个结点的二叉树采用标准链接存储结构,那么该二叉树所有结点共有_个空指针域。5.已知二叉树的前序序列为 ABDEGCFHIJ,中序序列为 DBGEAHFIJC,写出后序序列_。6.已知二叉树的后序序列为 FGDBHECA,中序序列为 BFDGAEHC ,并写出前序序列_。7.找出满足下列条件的二叉树1)先序和中序遍历,得到的结点访问顺序一样。_2)后序和中序遍历,得到的结点访问顺序一样。_3)先序和后序遍历,得到的结点访问顺序一样。_8.一棵含有 n 个结点的 k 叉树,可能达到的最大深度和最小深度各是多少?_9.一棵二叉树有 67 个结点,这些结点的度要么是

7、 0,要么是 2。这棵二叉树中度为 2 的结点有_个。10.含有 100 个结点的树有_条边。四、问答题 1.一棵深度为 h 的满 m 叉树具有如下性质 :第 h 层上的结点都是叶结点 ,其余各层上每个结点都有 m 棵非空子树。若按层次从上到下 ,每层从左到右的顺序从 1 开始对全部结点编号,试计算: (1)第 k 层结点数(1kh) 。(2)整棵树结点数。(3)编号为 i 的结点的双亲结点的编号。(4)编号为 i 的结点的第 j 个孩子结点( 若有)的编号。2.证明:一个满 k 叉树上的叶子结点数 n0 和非叶子结点数 n1 之间满足以下关系: n0=(k-1)n1+13.已知一组元素为(5

8、0,28,78,65,23,36,13,42,71 ),请完成以下操作:(1)画出按元素排列顺序逐点插入所生成的二叉排序树 BT。(2)分别计算在 BT 中查找各元素所要进行的元素间的比较次数及平均比较次数。(3)画出在 BT 中删除(23 后的二叉树。4.有七个带权结点,其权值分别为 3,7,8,2,6,10,14,试以它们为叶结点构造一棵哈夫曼树(请按照每个结点的左子树根结点的权小于等于右子树根结点的权的次序构造,并计算出带权路径长度 WPL 及该树的结点总数。5.有一电文共使用五种字符 a,b,c,d,e,其出现频率依次为 4,7,5,2,9。(1)试画出对应的编码哈夫曼树( 要求左子树

9、根结点的权小于等于右子树根结点的权)。(2)求出每个字符的晗夫曼编码。(3)求出传送电文的总长度。(4)并译出编码系列 1100011100010010 的相应电文。五、算法设计已知一棵具有 n 个结点的完全二叉树被顺序存储在一维数组 An中,试编写一个算法输出Ai结点的双亲和所有孩子。参考答案:一 、 选 择 题1. B 2.B 3. A 4. B 5. B 6.D 7、A 8、D 9、B 10、C 11、A 12、C 13、A 14、C 15、D 16、C 17 C 二 、 判 断 题 1 2 3 4三 、 填 空 题1、 树 的 结 点 个 数 至 少 为 1, 而 二 叉 树 的 结

10、点 个 数 可 以 为 0; 树 中 结 点 的 最 大 度 数 没 有 限 制 , 而 二 叉 树 结 点 的 最 大 度 数 不 能 超 过 2; 树 的 结 点 无 左 右 之 分 , 而 二 叉 树 的 结 点 有 左 右 之 分 。 2、 树 可 采 用 二 叉 树 的 存 储 结 构 并 利 用 二 叉 树 的 已 有 算 法 解 决 树 的 有 关 问 题 。 3、 4 4、 n+1 5、 DGEBHJIFCA 6、 ABDEGCEH7、 无 左 子 树 无 右 子 树 仅 一 个 结 点 的 二 叉 树 8、 最 大 n,最 小 log2n+1 9、 33 10、 99四、问答

11、题 1.答:(1)m k-1 (2) (m h-1)/ (m-1) (3)i=1 时,该结点为根,无双亲结点;否则其双亲结点的编号为 12mi(4)编号为 i 的结点的第 j 个孩子结点(若有) 的编号为(i-1)*m+1+j2.证明:设树结点为 n, 则 n=n0+n1因是满 k 叉树, 每个非叶子结点引 出 k 个分支,故有 k*n1 个分支。除根外,每个分支引出一个结点,则树共有 k*n1 +1 个结点。所以 n0+n1=k*n1+1n0=(k-1)*n1+1五 、 算 法 设 计void parent(int a,int n,int i)if(i=1) printf(无 双 亲 n);

12、return;Elseprintf(双 亲 :%dn,a(i-1)/2);void child(int a,int n,int i) /*i 为 序 号 */int queueMAX,front=0,tail=0,p; /* 队 列 作 为 辅 助 , 存 储 孩 子 的 序 号 */queue0=i;tail+;while(frontdata=ch;create(create(? void inorder(NODE *p) /中 序 编 历 二 叉 树 if(p!=NULL) inorder(p-lchild);? printf(%c ,p-data);? inorder(p-rchild)

13、;? ? int num=0;void count(NODE *p) /统 计 出 二 叉 树 中 单 孩 子 的 结 点 数 方 法 1if(p!=NULL)count(p-lchild);if(p-lchild!=NULL&p-rchild=NULL|p-lchild=NULL&p-rchild!=NULL)num+;count(p-rchild);void count1(NODE *p,int *num1)if(p!=NULL)count1(p-lchild,num1);if(p-lchild!=NULL&p-rchild=NULL|p-lchild=NULL&p-rchild!=NUL

14、L)(*num1)+;count1(p-rchild,num1);int onechild(NODE *t) /统 计 出 二 叉 树 中 单 孩 子 的 结 点 数 方 法 2int num1,num2;if(t=NULL) return(0);else if(t-lchild=NULL&t-rchild!=NULL|t-lchild!=NULL&t-rchild=NULL)return(onechild(t-lchild)+onechild(t-rchild)+1);elsenum1=onechild(t-lchild);num2=onechild(t-rchild);return(num

15、1+num2);int sum(NODE *t) /统 计 出 二 叉 树 中 所 有 结 点 数if(t=NULL) return(0);else return(sum(t-lchild)+sum(t-rchild)+1);int leaf(NODE *t) /统 计 出 二 叉 树 中 叶 子 结 点 数if(t=NULL) return(0);else if(t-lchild=NULLelsereturn(leaf(t-lchild)+leaf(t-rchild);void preorder1(NODE *root) /非 递 归 二 叉 树 前 序 编 历 NODE *p,*s100,*q; /q 为 p 的 双 亲 结 点int top=0; /top 为 栈 顶 指 针p=root;q=p;while(p!=N

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

当前位置:首页 > 高等教育 > 大学课件

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号