数据结构第六章树和二叉树练习及答案
数据结构课后习题答案及解析第六章
第六章树和二叉树(下载后用阅读版式视图或web版式可以看清)习题一、选择题1.有一“遗传”关系:设x是y的父亲,则x可以把它的属性遗传给y。
表示该遗传关系最适合的数据结构为( )。
A.向量B.树 C图 D.二叉树2.树最合适用来表示( )。
A.有序数据元素B元素之间具有分支层次关系的数据C无序数据元素 D.元素之间无联系的数据3.树B的层号表示为la,2b,3d,3e,2c,对应于下面选择的( )。
A. la (2b (3d,3e),2c)B. a(b(D,e),c)C. a(b(d,e),c)D. a(b,d(e),c)4.高度为h的完全二叉树至少有( )个结点,至多有( )个结点。
A. 2h_lB.h C.2h-1 D. 2h5.在一棵完全二叉树中,若编号为f的结点存在右孩子,则右子结点的编号为( )。
A. 2iB. 2i-lC. 2i+lD. 2i+26.一棵二叉树的广义表表示为a(b(c),d(e(,g(h)),f)),则该二叉树的高度为 ( )。
A.3B.4C.5D.67.深度为5的二叉树至多有( )个结点。
A. 31B. 32C. 16D. 108.假定在一棵二叉树中,双分支结点数为15,单分支结点数为30个,则叶子结点数为( )个。
A. 15B. 16C. 17D. 479.题图6-1中,( )是完全二叉树,( )是满二叉树。
..专业知识编辑整理..10.在题图6-2所示的二叉树中:(1)A结点是A.叶结点B根结点但不是分支结点 C根结点也是分支结点 D.分支结点但不是根结点(2)J结点是A.叶结点B.根结点但不是分支结点 C根结点也是分支结点 D.分支结点但不是根结点(3)F结点的兄弟结点是A.EB.D C.空 D.I(4)F结点的双亲结点是A.AB.BC.CD.D(5)树的深度为A.1B.2C.3D.4(6)B结点的深度为A.1B.2C.3D.4(7)A结点所在的层是A.1B.2C.3D.4..专业知识编辑整理..11.在一棵具有35个结点的完全二叉树中,该树的深度为( )。
数据结构习题第六章 树和二叉树答案
第六章树和二叉树注:参考答案只能作为参考,也是有错的,自己要学会辨别。
一、单项选择题1.A2.D3.A4.C5.B6.D7.E8. D9.C10.B11. C12.A13.D14.B15.C16.B17.D18.B19. D20.C二、判断题(在各题后填写“√”或“×”)1. 完全二叉树一定存在度为1的结点。
×2. 对于有N个结点的二叉树,其高度为log2n。
×3. 二叉树的遍历只是为了在应用中找到一种线性次序。
√4. 一棵一般树的结点的前序遍历和后序遍历分别与它相应二叉树的结点前序遍历和后序遍历是一致的。
×5. 用一维数组存储二叉树时,总是以前序遍历顺序存储结点。
×6.中序遍历一棵二叉排序树的结点就可得到排好序的结点序列√7.完全二叉树中,若一个结点没有左孩子,则它必是树叶。
√8. 二叉树只能用二叉链表表示。
×9. 给定一棵树,可以找到唯一的一棵二叉树与之对应。
√10. 用链表(llink-rlink)存储包含n个结点的二叉树,结点的2n个指针区域中有n-1个空指针。
×11.树形结构中元素之间存在一个对多个的关系。
√12.将一棵树转成二叉树,根结点没有左子树。
×13.度为二的树就是二叉树。
×14.二叉树中序线索化后,不存在空指针域。
×15.霍夫曼树的结点个数不能是偶数。
√16.哈夫曼树是带权路径长度最短的树,路径上权值较大的结点离根较近。
√三、填空题1.p->lchild==null && p->rchlid==null2.(1)2k-1 (2)2k-13.644. 2n n-1 n+15.先序遍历后序遍历中序遍历6..(1)2k-2+1(第k层1个结点,总结点个数是2H-1,其双亲是2H-1/2=2k-2)(2) ⎣log2i⎦+1 7.48.任何结点至多只有右子女的二叉树。
数据结构-习题-第六章-树
数据结构-习题-第六章-树和二叉树E F D G A B / + + * - C * 第六章 树和二叉树一、选择题1.已知一算术表达式的中缀形式为 A+B*C-D/E ,后缀形式为ABC*+DE/-,其前缀形式为( )A .-A+B*C/DE B. -A+B*CD/EC .-+*ABC/DE D. -+A*BC/DE【北京航空航天大学 1999 一、3 (2分)】2.算术表达式a+b*(c+d/e )转为后缀表达式后为( )【中山大学 1999 一、5】A .ab+cde/*B .abcde/+*+C .abcde/*++D .abcde*/++ 3. 设有一表示算术表达式的二叉树(见下图), 它所表示的算术表达式是( )【南京理工大学1999 一、20(2分)】A. A*B+C/(D*E)+(F-G)B.(A*B+C)/(D*E)+(F-G)C. (A*B+C)/(D*E+(F-G ))D.A*B+C/D*E+F-G4. 设树T 的度为4,其中度为1,2,3和4的结点个数分别为4,2,1,1 则T 中的叶子数为( )A .5B .6C .7D.8【南京理工大学 2000 一、8 (1.5分)】5. 在下述结论中,正确的是()【南京理工大学 1999 一、4 (1分)】①只有一个结点的二叉树的度为0; ②二叉树的度为2;③二叉树的左右子树可任意交换;④深度为K的完全二叉树的结点个数小于或等于深度相同的满二叉树。
A.①②③ B.②③④ C.②④ D.①④6. 设森林F对应的二叉树为B,它有m个结点,B的根为p,p的右子树结点个数为n,森林F中第一棵树的结点个数是()A.m-n B.m-n-1 C.n+1 D.条件不足,无法确定【南京理工大学2000 一、17(1.5分)】7. 树是结点的有限集合,它( (1))根结点,记为T。
其余结点分成为m(m>0)个((2))的集合T1,T2,…,Tm,每个集合又都是树,此时结点T称为Ti的父结点,Ti称为T的子结点(1≤i≤m)。
数据结构 第六章 树和二叉树作业及答案
第六章树和二叉树作业一、选择题(每题2分,共24分)。
1. 一棵二叉树的顺序存储情况如下:树中,度为2的结点数为( C )。
A.1 B.2 C.3 D.42. 一棵“完全二叉树”结点数为25,高度为(B )。
A.4 B.5 C.6 D.不确定3.下列说法中,(B )是正确的。
A. 二叉树就是度为2的树B. 二叉树中不存在度大于2的结点C. 二叉树是有序树D. 二叉树中每个结点的度均为24.一棵二叉树的前序遍历序列为ABCDEFG,它的中序遍历序列可能是(B )。
A. CABDEFGB. BCDAEFGC. DACEFBGD. ADBCFEG5.线索二叉树中的线索指的是(C )。
A.左孩子 B.遍历 C.指针 D.标志6. 建立线索二叉树的目的是(A )。
A. 方便查找某结点的前驱或后继B. 方便二叉树的插入与删除C. 方便查找某结点的双亲D. 使二叉树的遍历结果唯一7. 有 D )示意。
A.B.C.D.8. 一颗有2046个结点的完全二叉树的第10层上共有(B )个结点。
A. 511B. 512C. 1023D. 10249. 一棵完全二叉树一定是一棵(A )。
A. 平衡二叉树B. 二叉排序树C. 堆D. 哈夫曼树10.某二叉树的中序遍历序列和后序遍历序列正好相反,则该二叉树一定是( C )的二叉树。
A .空或只有一个结点B .高度等于其结点数C .任一结点无左孩子D .任一结点无右孩子11.一棵二叉树的顺序存储情况如下:1 2 3 4 5 6 7 8 9 10 11 12 13 14 15A B C D E 0 F 0 0 G H 0 0 0 X结点D 的左孩子结点为( D )。
A .EB .C C .FD .没有12.一棵“完全二叉树”结点数为25,高度为( B )。
A .4B .5C .6D .不确定二、填空题(每空3分,共18分)。
1. 树的路径长度:是从树根到每个结点的路径长度之和。
对结点数相同的树来说,路径长度最短的是 完全 二叉树。
数据结构第6章作业 树和二叉树答案
第6章树和二叉树答案一、判断正误(√)1. 若二叉树用二叉链表作存贮结构,则在n个结点的二叉树链表中只有n—1个非空指针域。
(×)2.二叉树中每个结点的两棵子树的高度差等于1。
(√)3.二叉树中每个结点的两棵子树是有序的。
(×)4.二叉树中每个结点有两棵非空子树或有两棵空子树。
(×)5.二叉树中每个结点的关键字值大于其左非空子树(若存在的话)所有结点的关键字值,且小于其右非空子树(若存在的话)所有结点的关键字值。
(应当是二叉排序树的特点)(×)6.二叉树中所有结点个数是2k-1-1,其中k是树的深度。
(应2i-1)(×)7.二叉树中所有结点,如果不存在非空左子树,则不存在非空右子树。
(×)8.对于一棵非空二叉树,它的根结点作为第一层,则它的第i层上最多能有2i—1个结点。
(应2i-1)(√)9.用二叉链表法(link-rlink)存储包含n个结点的二叉树,结点的2n个指针区域中有n+1个为空指针。
(正确。
用二叉链表存储包含n个结点的二叉树,结点共有2n个链域。
由于二叉树中,除根结点外,每一个结点有且仅有一个双亲,所以只有n-1个结点的链域存放指向非空子女结点的指针,还有n+1个空指针。
)即有后继链接的指针仅n-1个。
(√)10. 〖01年计算机系研题〗具有12个结点的完全二叉树有5个度为2的结点。
最快方法:用叶子数=[n/2]=6,再求n2=n0-1=5二、填空题1.由3个结点所构成的二叉树有5种形态。
2. 一棵深度为6的满二叉树有n1+n2=0+ n2= n0-1=31 个分支结点和26-1 =32个叶子。
注:满二叉树没有度为1的结点,所以分支结点数就是二度结点数。
3.一棵具有257个结点的完全二叉树,它的深度为9。
(注:用⎣ log2(n) ⎦+1= ⎣ 8.xx ⎦+1=94.设一棵完全二叉树有700个结点,则共有350个叶子结点。
数据结构二叉树习题含答案
第 6 章树和二叉树1.选择题( 1)把一棵树变换为二叉树后,这棵二叉树的形态是()。
A.独一的B.有多种C.有多种,但根结点都没有左孩子D.有多种,但根结点都没有右孩子( 2)由 3 个结点能够结构出多少种不一样的二叉树?()A. 2 B . 3 C . 4 D. 5( 3)一棵完整二叉树上有1001 个结点,此中叶子结点的个数是()。
A. 250 B . 500 C . 254 D. 501( 4)一个拥有 1025 个结点的二叉树的高h 为()。
A. 11 B . 10 C.11 至 1025 之间 D .10 至 1024 之间( 5)深度为 h 的满 m叉树的第 k 层有()个结点。
(1=<k=<h)k-1B kCh-1 hA. m . m-1 . m D.m-1( 6)利用二叉链表储存树,则根结点的右指针是()。
A.指向最左孩子 B .指向最右孩子 C .空 D .非空( 7)对二叉树的结点从 1 开始进行连续编号,要求每个结点的编号大于其左、右孩子的编号,同一结点的左右孩子中,其左孩子的编号小于其右孩子的编号,可采纳()遍历实现编号。
A.先序 B. 中序 C. 后序 D.从根开始按层次遍历(8)若二叉树采纳二叉链表储存结构,要互换其全部分支结点左、右子树的地点,利用()遍历方法最适合。
A.前序B.中序C.后序D.按层次(9)在以下储存形式中,()不是树的储存形式?A.双亲表示法 B .孩子链表表示法 C .孩子兄弟表示法D.次序储存表示法( 10)一棵非空的二叉树的先序遍历序列与后序遍历序列正好相反,则该二叉树必定满足()。
A.全部的结点均无左孩子B.全部的结点均无右孩子C.只有一个叶子结点D.是随意一棵二叉树( 11)某二叉树的前序序列和后序序列正好相反,则该二叉树必定是()的二叉树。
A.空或只有一个结点B.任一结点无左子树C.高度等于其结点数 D .任一结点无右子树( 12)若 X 是二叉中序线索树中一个有左孩子的结点,且 X 不为根,则 X 的前驱为()。
数据结构习题与答案--树和二叉树
第六章树和二叉树一、判断题( t )01、若二叉树用二叉链表作存贮结构,则在n个结点的二叉树链表中只有n—1个非空指针域。
( f )02、二叉树中每个结点的两棵子树的高度差等于1。
(t )03、二叉树中每个结点的两棵子树是有序的。
( f )04、二叉树中每个结点有两棵非空子树或有两棵空子树。
( f )05、二叉树中所有结点个数是2k-1-1,其中k是树的深度。
(f )06、二叉树中所有结点,如果不存在非空左子树,则不存在非空右子树。
( f )07、对于一棵非空二叉树,它的根结点作为第一层,则它的第i层上最多能有2i—1个结点。
(t )08、用二叉链表法存储包含n个结点的二叉树,结点的2n个指针区域中有n+1个为空指针。
(t)09、具有12个结点的完全二叉树有5个度为2的结点。
( f )10、二叉树中每个结点的关键字值大于其左非空子树(若存在的话)所有结点的关键字值,且小于其右非空子树(若存在的话)所有结点的关键字值。
( f )11、二叉树按某种顺序线索化后,任一结点均有指向其前驱和后续的线索。
( t )12、二叉树的先序遍历序列中,任意一个结点均处在其孩子结点的前面。
二、填空题01、由3个结点所构成的二叉树有_5_种形态。
02、一棵深度为6的满二叉树有____个分支结点和____个叶子。
03、一棵具有257个结点的完全二叉树,它的深度为____。
04、设一棵完全二叉树有700个结点,则共有____个叶子结点。
05、设一棵完全二叉树具有1000个结点,则此完全二叉树有____个叶子结点,有____个度为2的结点,有____个结点只有非空左子树,有____个结点只有非空右子树。
06、一棵含有n个结点的k叉树,可能达到的最大深度为____,最小深度为____。
07、二叉树的基本组成部分是:根(N)、左子树(L)和右子树(R)。
因而二叉树的遍历次序有六种。
最常用的是三种:前序法(即按N L R次序),后序法(即按LRN次序)和中序法(也称对称序法,即按L N R次序)。
数据结构(树与二叉树)习题与答案
一、单选题1、已知一算术表达式的中缀形式为 A-B/C+D*E,前缀形式为+-A/BC*DE,其后缀形式为( )。
A.ABC/-DE*+B.AB/C-D*E+C. A-BC/DE*+D. ABCDE/-*+正确答案:A2、有关二叉树下列说法正确的是()。
A.二叉树中任何一个结点的度都为2B.一棵二叉树的度可以小于2C.二叉树中每个结点的度都为2D.二叉树中至少有一个结点的度为2正确答案:B3、在一棵高度为k的满二叉树中,结点总数为()。
A.2k-1B. 2k-1C. 2k-1+1D.2k正确答案:B4、某二叉树中有60个叶子结点,则该二叉树中度为2的结点个数为()。
A.不确定B.60C.59D.61正确答案:C解析:任意二叉树中,n0=n2+15、高度为7的完全二叉树,最少有()个结点。
A.127B.128C.63D.64正确答案:D解析:前6层都是满的,最后一层(第7层)近1个结点。
可保证题目条件。
6、高度为7的二叉树,最少有()个结点。
A.7B.127C.13D.64正确答案:A解析:每层只有1个结点。
共7个即可构成一个高度为7的二叉树。
7、对任意一棵有n个结点的树,这n个结点的度之和为( )。
A.n-1B.2*nC.n+2D.n正确答案:A解析:所有结点的度之和为分支个数,分支个数即为结点个数-18、在下列存储形式中,()不是树的存储形式。
A.双亲表示法B.孩子-兄弟表示法C.孩子链表表示法D.顺序存储表示法正确答案:D9、对二叉树中的结点进行编号,要求根结点的编号最小,左孩子结点编号比右孩子结点编号小。
则应该采用()遍历方法对其进行编号。
A.层次B.先序C.后序D.中序正确答案:B10、某二叉树中有60个叶子结点,则该二叉树中度为2的结点个数为()。
A. 59B.61C.60D.不一定正确答案:A11、树的后根遍历,相当于对应二叉树的()遍历。
A.中序B.后序C.层次D.先序正确答案:A二、判断题1、完全二叉树一定存在度为1的结点。
数据结构与算法第六章课后答案第六章 树和二叉树
第6章 树和二叉树(参考答案)6.1(1)根结点a6.2三个结点的树的形态: 三个结点的二叉树的形态:(1) (1) (2) (4) (5)6.3 设树的结点数是n ,则n=n0+n1+n2+……+nm+ (1)设树的分支数为B ,有n=B+1n=1n1+2n2+……+mnm+1 (2)由(1)和(2)有:n0=n2+2n3+……+(m-1)nm+16.4(1) k i-1 (i 为层数)(2) (n-2)/k+1(3) (n-1)*k+i+1(4) (n-1)%k !=0; 其右兄弟的编号 n+16.5(1)顺序存储结构注:#为空结点6.6(1) 前序 ABDGCEFH(2) 中序 DGBAECHF(3) 后序 GDBEHFCA6.7(1) 空二叉树或任何结点均无左子树的非空二叉树(2) 空二叉树或任何结点均无右子树的非空二叉树(3) 空二叉树或只有根结点的二叉树6.8int height(bitree bt)// bt是以二叉链表为存储结构的二叉树,本算法求二叉树bt的高度{ int bl,br; // 局部变量,分别表示二叉树左、右子树的高度if (bt==null) return(0);else { bl=height(bt->lchild);br=height(bt->rchild);return(bl>br? bl+1: br+1); // 左右子树高度的大者加1(根) }}// 算法结束6.9void preorder(cbt[],int n,int i);// cbt是以完全二叉树形式存储的n个结点的二叉树,i是数// 组下标,初始调用时为1。
本算法以非递归形式前序遍历该二叉树{ int i=1,s[],top=0; // s是栈,栈中元素是二叉树结点在cbt中的序号 // top是栈顶指针,栈空时top=0if (n<=0) { printf(“输入错误”);exit(0);}while (i<=n ||top>0){ while(i<=n){visit(cbt[i]); // 访问根结点if (2*i+1<=n) s[++top]=2*i+1; //若右子树非空,其编号进栈i=2*i;// 先序访问左子树}if (top>0) i=s[top--]; // 退栈,先序访问右子树} // END OF while (i<=n ||top>0)}// 算法结束//以下是非完全二叉树顺序存储时的递归遍历算法,“虚结点”用‘*’表示void preorder(bt[],int n,int i);// bt是以完全二叉树形式存储的一维数组,n是数组元素个数。
数据结构考研试题精选及答案第6章 树和二叉树答案
第6章树和二叉树部分答案解释如下。
12. 由二叉树结点的公式:n=n0+n1+n2=n0+n1+(n0-1)=2n0+n1-1,因为n=1001,所以1002=2n0+n1,在完全二叉树树中,n1只能取0或1,在本题中只能取0,故n=501,因此选E。
42.前序序列是“根左右”,后序序列是“左右根”,若要这两个序列相反,只有单支树,所以本题的A和B均对,单支树的特点是只有一个叶子结点,故C是最合适的,选C。
A或B 都不全。
由本题可解答44题。
47. 左子树为空的二叉树的根结点的左线索为空(无前驱),先序序列的最后结点的右线索为空(无后继),共2个空链域。
52.线索二叉树是利用二叉树的空链域加上线索,n个结点的二叉树有n+1个空链域。
部分答案解释如下。
6.只有在确定何序(前序、中序、后序或层次)遍历后,遍历结果才唯一。
19.任何结点至多只有左子树的二叉树的遍历就不需要栈。
24. 只对完全二叉树适用,编号为i的结点的左儿子的编号为2i(2i<=n),右儿子是2i+1(2i+1<=n)37. 其中序前驱是其左子树上按中序遍历的最右边的结点(叶子或无右子女),该结点无右孩子。
38 . 新插入的结点都是叶子结点。
42. 在二叉树上,对有左右子女的结点,其中序前驱是其左子树上按中序遍历的最右边的结点(该结点的后继指针指向祖先),中序后继是其右子树上按中序遍历的最左边的结点(该结点的前驱指针指向祖先)。
44.非空二叉树中序遍历第一个结点无前驱,最后一个结点无后继,这两个结点的前驱线索和后继线索为空指针。
三.填空题1.(1)根结点(2)左子树(3)右子树2.(1)双亲链表表示法(2)孩子链表表示法(3)孩子兄弟表示法3.p->lchild==null && p->rchlid==null 4.(1) ++a*b3*4-cd (2)18 5.平衡因子6. 97. 128.(1)2k-1 (2)2k-19.(1)2H-1 (2)2H-1(3)H=⎣log2N⎦+110. 用顺序存储二叉树时,要按完全二叉树的形式存储,非完全二叉树存储时,要加“虚结点”。
第6章 树和二叉树-习题-答案
第6章树和二叉树习题答案1.从概念上讲,树,森林和二叉树是三种不同的数据结构,将树,森林转化为二叉树的基本目的是什么,并指出树和二叉树的主要区别。
答:树的孩子兄弟链表表示法和二叉树二叉链表表示法,本质是一样的,只是解释不同,也就是说树(树是森林的特例,即森林中只有一棵树的特殊情况)可用二叉树唯一表示,并可使用二叉树的一些算法去解决树和森林中的问题。
树和二叉树的区别有三:一是二叉树的度至多为2,树无此限制;二是二叉树有左右子树之分,即使在只有一个分枝的情况下,也必须指出是左子树还是右子树,树无此限制;三是二叉树允许为空,树一般不允许为空(个别书上允许为空)。
2.请分析线性表、树、广义表的主要结构特点,以及相互的差异与关联。
答:线性表属于约束最强的线性结构,在非空线性表中,只有一个“第一个”元素,也只有一个“最后一个”元素;除第一个元素外,每个元素有唯一前驱;除最后一个元素外,每个元素有唯一后继。
树是一种层次结构,有且只有一个根结点,每个结点可以有多个子女,但只有一个双亲(根无双亲),从这个意义上说存在一(双亲)对多(子女)的关系。
广义表中的元素既可以是原子,也可以是子表,子表可以为它表共享。
从表中套表意义上说,广义表也是层次结构。
从逻辑上讲,树和广义表均属非线性结构。
但在以下意义上,又蜕变为线性结构。
如度为1的树,以及广义表中的元素都是原子时。
另外,广义表从元素之间的关系可看成前驱和后继,也符合线性表,但这时元素有原子,也有子表,即元素并不属于同一数据对象。
3.在二叉树的Llink-Rlink存储表示中,引入“线索”的好处是什么?答:在二叉链表表示的二叉树中,引入线索的目的主要是便于查找结点的前驱和后继。
因为若知道各结点的后继,二叉树的遍历就变成非常简单。
二叉链表结构查结点的左右子女非常方便,但其前驱和后继是在遍历中形成的。
为了将非线性结构二叉树的结点排成线性序列,利用结点的空链域,左链为空时用作前驱指针,右链为空时作为后继指针。
第6章_数据结构习题题目及答案_树和二叉树_参考答案
一、基础知识题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=86.2一棵完全二叉树上有1001个结点,求叶子结点的个数。
【解答】因为在任意二叉树中度为2 的结点数n2和叶子结点数n0有如下关系:n2=n0-1,所以设二叉树的结点数为n, 度为1的结点数为n1,则n= n0+ n1+ n2n=2n0+n1-11002=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个结点仅有一个孩子,则该二叉树的总结点数是多少。
数据结构树和二叉树练习及答案
一、选择题1、设T是一棵树,T’是对应于x的二叉树,则T的先根次序遍历和T’的()次序遍历相同。
A、先根B、中根C、后根D、以上都不是2、3、若二叉树的后序遍历序列为dabec,中序遍历序列为debac,则前序序列遍历为()。
A、acbedB、decabC、deabcD、cedba4、具有35个结点的完全二叉树的深度为()A、5B、6C、7D、85、将一棵有100个结点的完全二叉树从上到下,从左到右依次对结点进行编号,根结点的编号为1,则编号为49的结点的左孩子结点编号为()A、98B、99C、50D、486、某二叉树的前序和后序序列正好相反,则该二叉树一定是()的二叉树。
A、空或只有一个结点B、高度等于其结点数C、任一结点无左孩子D、任一结点无左孩子7、二叉树在线索化后,仍不能有效求解的问题是()A、先根线索二叉树中求先根后继B、中根线索二叉树中求中根后继C、中根线索二叉树中求中根前驱D、后根线索二叉树中求后根后继8、在线索化二叉树中,t所指结点没有左子树的充足条件是()A、t-lchild==NULLB、t->ltag==1C、t->ltag==1&&t->lchild==NULLD、以上都不对9、设高度为h的二叉树上只有度为0和度为2的结点,则此类二叉树中所包含的结点数至少为()A、2hB、2h-1C、2h+1D、h+110、深度为5的二叉树至多有()个结点。
A、16B、32C、31D、1011、在一非空二叉树的中序遍历序列中,根结点的右边()A、只有右子树上的所有结点B、只有右子树上的部分结点C、只有左子树上的所有结点D、只有左子树上的部分结点12、树最适合用来表示()A、有序数据元素B、无序数据元素C、元素之间具有分支层次关系的数据D、元素之间无联系的数据13、任何一棵二叉树的叶结点在先序、中序和后序遍历序列中的相对次序()A、不发生改变B、发生改变C、不能确定D、以上都不对14、设n,m为一棵二叉树上的两个结点,在中序遍历时,n在m前的条件是()A、n在m右方B、n是m祖先C、n在m左方D、n是m子孙15、线索二叉树是一种()结构A、逻辑B、逻辑和存储C、物理D、线性16、森林的后根遍历序列与其对应二叉树的()遍历序列一致。
数据结构第6章二叉树自测题参考答案
第6章树和二叉树自测卷解答一、下面是有关二叉树的叙述,请判断正误(√)1. 若二叉树用二叉链表作存贮结构,则在n个结点的二叉树链表中只有n—1个非空指针域。
(×)2.二叉树中每个结点的两棵子树的高度差等于1。
(√)3.二叉树中每个结点的两棵子树是有序的。
(×)4.二叉树中每个结点有两棵非空子树或有两棵空子树。
(×)5.二叉树中每个结点的关键字值大于其左非空子树(若存在的话)所有结点的关键字值,且小于其右非空子树(若存在的话)所有结点的关键字值。
(应当是二叉排序树的特点)(×)6.二叉树中所有结点个数是2k-1-1,其中k是树的深度。
(应2i-1)(×)7.二叉树中所有结点,如果不存在非空左子树,则不存在非空右子树。
(×)8.对于一棵非空二叉树,它的根结点作为第一层,则它的第i层上最多能有2i—1个结点。
(应2i-1)(√)9.用二叉链表法(link-rlink)存储包含n个结点的二叉树,结点的2n个指针区域中有n+1个为空指针。
(正确。
用二叉链表存储包含n个结点的二叉树,结点共有2n个链域。
由于二叉树中,除根结点外,每一个结点有且仅有一个双亲,所以只有n-1个结点的链域存放指向非空子女结点的指针,还有n+1个空指针。
)即有后继链接的指针仅n-1个。
(√)10. 具有12个结点的完全二叉树有5个度为2的结点。
最快方法:用叶子数=[n/2]=6,再求n2=n0-1=5二、填空(每空1分,共15分)1.由3个结点所构成的二叉树有5种形态。
2. 一棵深度为6的满二叉树有n1+n2=0+ n2= n0-1=31 个分支结点和26-1 =32个叶子。
注:满二叉树没有度为1的结点,所以分支结点数就是二度结点数。
3.一棵具有257个结点的完全二叉树,它的深度为9。
(注:用 log2(n) +1= 8.xx +1=94.设一棵完全二叉树有700个结点,则共有 350个叶子结点。
数据结构课后习题(第6章)
【课后习题】第6章树和二叉树网络工程2010级()班学号:姓名:一、填空题(每空1分,共16分)1.从逻辑结构看,树是典型的。
2.设一棵完全二叉树具有999个结点,则此完全二叉树有个叶子结点,有个度为2的结点,有个度为1的结点。
3.由n个权值构成的哈夫曼树共有个结点。
4.在线索化二叉树中,T所指结点没有左子树的充要条件是。
5.在非空树上,_____没有直接前趋。
6.深度为k的二叉树最多有结点,最少有个结点。
7.若按层次顺序将一棵有n个结点的完全二叉树的所有结点从1到n编号,那么当i为且小于n时,结点i的右兄弟是结点,否则结点i没有右兄弟。
8.N个结点的二叉树采用二叉链表存放,共有空链域个数为。
9.一棵深度为7的满二叉树有___ ___个非终端结点。
10.将一棵树转换为二叉树表示后,该二叉树的根结点没有。
11.采用二叉树来表示树时,树的先根次序遍历结果与其对应的二叉树的遍历结果是一样的。
12.一棵Huffman树是带权路径长度最短的二叉树,权值的外结点离根较远。
二、判断题(如果正确,在对应位置打“√”,否则打“⨯”。
每题0.5分,共5分)1.对于一棵非空二叉树,它的根结点作为第一层,则它的第i层上最多能有2i-1个结点。
2.二叉树的前序遍历并不能唯一确定这棵树,但是,如果我们还知道该二叉树的根结点是那一个,则可以确定这棵二叉树。
3.一棵树中的叶子结点数一定等于与其对应的二叉树中的叶子结点数。
4.度≤2的树就是二叉树。
5.一棵Huffman树是带权路径长度最短的二叉树,权值较大的外结点离根较远。
6.采用二叉树来表示树时,树的先根次序遍历结果与其对应的二叉树的前序遍历结果是一样的。
7.不存在有偶数个结点的满二叉树。
8.满二叉树一定是完全二叉树,而完全二叉树不一定是满二叉树。
9.已知二叉树的前序遍历顺序和中序遍历顺序,可以惟一确定一棵二叉树;10.已知二叉树的前序遍历顺序和后序遍历顺序,不能惟一确定一棵二叉树;三、单项选择(请将正确答案的代号填写在下表对应题号下面。
数据结构第六章 树和二叉树课后习题答案
第六章课后习题6、1、各层的结点数目是:K2、编号为n的结点的双亲结点是:<=(n-2)/k的最大整数3、编号为n的结点的第i个孩子结点编号是:k*(n-1)+1+i4、编号为n的结点有右兄弟的条件是:(n-1)能被k整除右兄弟的编号是:n+1.7、1、先序序列和中序序列相同:空二叉树或没有左子树的二叉树。
2、中序序列和后序序列相同:空二叉树或没有右子树的二叉树。
3、先序序列和后序序列相同:空二叉树或只有根的二叉树。
9、中序序列:BDCEAFHG和后序序列:DECBHGFA的二叉树为:AB FC GD E H先序序列:ABCDEFGH算法设计:3、typedef struct{int data[100];int top;}seqstack;seqstack *s;Perorder(char a[],int n){int i=1,count=1;s->top=-1;if(n==0)return(0);else{if(I<=n){s->top++;s->data[s->top]=a[I];}while(count<n){printf(“%c”,s->data[s->top]);count++;s->top--;if(s->data[s->top]);==a[i]){ printf(“%c”,s->data[s->top]);count++;s->top--;}if((2*i+1)<n){i=2*i;s->top++;s->data[s->top]=a[i+1];s->top++;s->data[s->top]=a[i];}else if(a*i<n){i=2*i;s->top++;s->data[s->top]=a[i];}else if(i/2%2==1)i=i/2/2+1;else i=i/2+1;}}}main(){char A[]=“kognwyuvb”;int n=strlen(A);s=(seqstack *)malloc(sizeof(seqstack)); printf(“\n”);Perorder(A,n);}。
目前最完整数据结构1800题包括完整答案第六章树和二叉树
第六章 树和二叉树一.选择题1.已知一算术表达式地中缀形式为 A+B*C-D/E,后缀形式为ABC*+DE/-,其前缀形式为( )A .-A+B*C/DE B. -A+B*CD/E C .-+*ABC/DE D. -+A*BC/DE【北京航空航天大学 1999 一.3 (2分)】2.算术表达式a+b*(c+d/e )转为后缀表达式后为( )【中山大学 1999 一.5】A .ab+cde/*B .abcde/+*+C .3. 设有一表示算术表达式地二叉树(见下图), 它所表示地算术表达式是( ) 【南京理工大学1999 一.20(2分)】 C. (A*B+C)/(D*E+(F-G )) D. A*B+C/D*E+F-G4. 设树T 地度为4,其中度为1,2,3和4地结点个数分别为4,2,1,1 则T 中地叶子数为( )A .5B .6C .7D .8【南京理工大学 2000 一.8 (1.5分)】5. 在下述结论中,正确地是( )【南京理工大学 1999 一.4 (1分)】①只有一个结点地二叉树地度为0; ②二叉树地度为2; ③二叉树地左右子树可任意交换;④深度为K 地完全二叉树地结点个数小于或等于深度相同地满二叉树.A .①②③B .②③④C .②④D .①④6. 设森林F 对应地二叉树为B,它有m 个结点,B 地根为p,p 地右子树结点个数为n,森林F 中第一棵树地结点个数是( )A .m-nB .m-n-1C .n+1D .条件不足,无法确定 【南京理工大学2000 一.17(1.5分)】7. 树是结点地有限集合,它( (1))根结点,记为T.其余结点分成为m (m>0)个((2))地集合T1,T2, …,Tm,每个集合又都是树,此时结点T 称为Ti 地父结点,Ti 称为T 地子结点(1≤i ≤m ).一个结点地子结点个数称为该结点地( (3) ).二叉树与树是两个不同地概念,二叉树也是结点地有限集合,它((4))根结点.可以把树地根结点地层数定义为1,其他结点地层数等于其父结点所在层数加上1.令T 是一棵二叉树,Ki 和Kj 是T 中子结点数小于2地结点中地任意两个,它们所在地层数分别为λKi 和λKj,当关系式│λKi-λKj │≤1一定成立时,则称T 为一棵((5)).供选择地答案:(1)(4) A. 有0个或1个 B. 有0个或多个 C. 有且只有一个 D. 有1个或1个以上(2) A. 互不相交 B.允许相交 C.允许叶结点相交 D.允许树枝结点相交(3) A. 权 B.维数 C.次数 D.序(5) A. 丰满树 B.查找树 C.平衡树 D.完全树 【上海海运学院1999二.2(5分)】8.若一棵二叉树具有10个度为2地结点,5个度为1地结点,则度为0地结点个数是( )A.9 B.11 C.15 D.不确定【北京工商大学2001一.7(3分)】9.在一棵三元树中度为3地结点数为2个,度为2地结点数为1个,度为1地结点数为2个,则度为0地结点数为()个A.4 B.5 C.6 D.7 【哈尔滨工业大学 2001二.2 (2分)】10.设森林F中有三棵树,第一,第二,第三棵树地结点个数分别为M1,M2和M3.与森林F对应地二叉树根结点地右子树上地结点个数是().【北方交通大学 2001一.16 (2分)】A.M1 B.M1+M2 C.M3 D.M2+M311.具有10个叶结点地二叉树中有()个度为2地结点,【北京航空航天大学2000 一.5(2分)】A.8 B.9 C.10 D.ll12.一棵完全二叉树上有1001个结点,其中叶子结点地个数是()【西安交通大学 1996 三.2 (3分)】A. 250 B. 500 C.254 D.505 E.以上答案都不对13. 设给定权值总数有n 个,其哈夫曼树地结点总数为( ) 【福州大学 1998一.5 (2分)】A.不确定 B.2n C.2n+1 D.2n-114. 有n个叶子地哈夫曼树地结点总数为().【青岛大学 2002 二.1 (2分)】A.不确定 B.2n C.2n+1 D.2n-115.若度为m地哈夫曼树中,其叶结点个数为n,则非叶结点地个数为().【中科院计算所1999一.2(2分)】A.n-1 B.ën/mû-1 C.é(n-1)/(m-1)ù D.én/(m-1)ù-1 E.é(n+1)/(m+1)ù-116. 有关二叉树下列说法正确地是()【南京理工大学 2000 一.11 (1.5分)】A.二叉树地度为2 B.一棵二叉树地度可以小于2 C.二叉树中至少有一个结点地度为2 D.二叉树中任何一个结点地度都为2 17.二叉树地第I层上最多含有结点数为()【中山大学1998二.7 (2分)】【北京理工大学 2001 六.5(2分)】A.2I B. 2I-1-1 C. 2I-1 D.2I -118. 一个具有1025个结点地二叉树地高h为()【南京理工大学 1999 一.19(2分)】A.11 B.10 C.11至1025之间 D.10至1024之间19.一棵二叉树高度为h,所有结点地度或为0,或为2,则这棵二叉树最少有( )结点A.2h B.2h-1 C.2h+1 D.h+1 【南京理工大学2001一.11(1.5分)】20.对于有n 个结点地二叉树, 其高度为()【武汉交通科技大学 1996 一.5(4分)】A.nlog2n B.log2n C.ëlog2nû|+1 D.不确定21. 一棵具有 n个结点地完全二叉树地树高度(深度)是()【南京理工大学1996一.8 (2分)】A.ëlognû+1 B.logn+1 C.ëlognû D.logn-122.深度为h地满m叉树地第k层有()个结点.(1=<k=<h)【北京航空航天大学2000一.4(2分)】A.mk-1 B.mk-1 C.mh-1 D.mh-123.在一棵高度为k地满二叉树中,结点总数为()【北京工商大学 2001 一.3(3分)】A.2k-1 B.2k C.2k-1 D.ëlog2kû+124.高度为 K地二叉树最大地结点数为().【山东大学 2001 二.3 (1分)】A.2k B.2k-1 C.2k -1 D.2k-1-125. 一棵树高为K地完全二叉树至少有()个结点【南京理工大学 1998 一.3(2分)】A.2k –1 B. 2k-1 –1 C. 2k-1 D. 2k26. 将有关二叉树地概念推广到三叉树,则一棵有244个结点地完全三叉树地高度()A.4 B.5 C.6 D.7 【南京理工大学2000一.5 1.5分)】27. 利用二叉链表存储树,则根结点地右指针是().【青岛大学 2001 五.5 (2分)】A.指向最左孩子 B.指向最右孩子 C.空 D.非空28.对二叉树地结点从1开始进行连续编号,要求每个结点地编号大于其左.右孩子地编号,同一结点地左右孩子中,其左孩子地编号小于其右孩子地编号,可采用( )次序地遍历实现编号.【北京理工大学 2000 一.4 (2分)】A.先序 B. 中序 C. 后序 D. 从根开始按层次遍历29.树地后根遍历序列等同于该树对应地二叉树地( ). 【北京理工大学 2001六.6 (2分)】A. 先序序列B. 中序序列C. 后序序列30.若二叉树采用二叉链表存储结构,要交换其所有分支结点左.右子树地位置,利用( )遍历方法最合适.A.前序 B.中序 C.后序 D.按层次【北京航空航天大学 1999一.4 (2分)】31.在下列存储形式中,哪一个不是树地存储形式?()【北方交通大学 2001一.23 (2分)】A.双亲表示法 B.孩子链表表示法 C.孩子兄弟表示法 D.顺序存储表示法32.一棵二叉树地前序遍历序列为ABCDEFG,它地中序遍历序列可能是()【北京工业大学 2001 一.2 (2分)】A.CABDEFG B.ABCDEFG C.DACEFBG D.ADCFEG 33.已知一棵二叉树地前序遍历结果为ABCDEF,中序遍历结果为CBAEDF,则后序遍历地结果为().A.CBEFDA B. FEDCBA C. CBEDFA D.不定【浙江大学 1999 四.2 ( 4分)】34.已知某二叉树地后序遍历序列是dabec, 中序遍历序列是debac , 它地前序遍历是().A.acbed B.decab C.deabc D.cedba 【山东大学 2001二.7 ( 1分)】35. 某二叉树中序序列为A,B,C,D,E,F,G,后序序列为B,D,C,A,F,G,E 则前序序列是:A.E,G,F,A,C,D,B B.E,A,C,B,D,G,F C.E,A,G,C,F,B,D D.上面地都不对【南京理工大学 2000 一.14 (1.5分)】36. 上题地二叉树对应地森林包括多少棵树()【南京理工大学 2000 一.15 (1.5分)】A.l B.2 C.3 D.概念上是错误地37.二叉树地先序遍历和中序遍历如下:先序遍历:EFHIGJK;中序遍历: HFIEJKG .该二叉树根地右子树地根是:【北方交通大学 2001 一.21(2分)】A. EB. FC. GD. H38.将一棵树t 转换为孩子—兄弟链表表示地二叉树h,则t地后根序遍历是h 地A.前序遍历 B.中序遍历 C.后序遍历()【北京邮电大学 2001一.2 (2分)】39. 某二叉树T有n个结点,设按某种顺序对T中地每个结点进行编号,编号为1,2,… ,n,且有如下性质:T中任一结点V,其编号等于左子树上地最小编号减1,而V地右子树地结点中,其最小编号等于V左子树上结点地最大编号加1.这时是按( )编号地.A.中序遍历序列B.前序遍历序列C.后序遍历序列D.层次顺序【长沙铁道学院1998三.1(2分)】40.下面地说法中正确地是().(1)任何一棵二叉树地叶子结点在三种遍历中地相对次序不变;(2)按二叉树定义,具有三个结点地二叉树共有6种.A.(1)(2) B.(1) C.(2) D.(1).(2)都错【南京理工大学 2001 一.10 (1.5分)】41.对于前序遍历与中序遍历结果相同地二叉树为(1);对于前序遍历和后序遍历结果相同地二叉树为(2).【中科院计算所 1999 一.4 (4分)】A.一般二叉树 B.只有根结点地二叉树 C.根结点无左孩子地二叉树D.根结点无右孩子地二叉树 E.所有结点只有左子数地二叉树 F.所有结点只有右子树地二叉树42.一棵非空地二叉树地先序遍历序列与后序遍历序列正好相反,则该二叉树一定满足()【南开大学 2000 一.2】A.所有地结点均无左孩子B.所有地结点均无右孩子C.只有一个叶子结点D.是任意一棵二叉树43.在二叉树结点地先序序列,中序序列和后序序列中,所有叶子结点地先后顺序()A.都不相同B.完全相同 C.先序和中序相同,而与后序不同D.中序和后序相同,而与先序不同【北方交通大学 2001 一.25 (2分)】44.某二叉树地前序序列和后序序列正好相反,则该二叉树一定是()地二叉树.【武汉大学2000二.4】A.空或只有一个结点 B.任一结点无左子树 C.高度等于其结点数D.任一结点无右子树45.在完全二叉树中,若一个结点是叶结点,则它没().【北方交通大学 2001一.22 (2分)】A.左子结点 B.右子结点 C.左子结点和右子结点 D.左子结点,右子结点和兄弟结点46.在下列情况中,可称为二叉树地是()A.每个结点至多有两棵子树地树 B. 哈夫曼树 C.每个结点至多有两棵子树地有序树D. 每个结点只有一棵右子树 E.以上答案都不对【西安交通大学 1996 三.4 (3分)】47. 一棵左子树为空地二叉树在先序线索化后,其中空地链域地个数是:( )A.不确定 B. 0 C. 1 D. 2 【合肥工业大学 1999 一.5 (48. 一棵左右子树均不空地二叉树在先序线索化后,其中空地链域地个数是:( ).A. 0B. 1C. 2D. 不确定【合肥工业大学2000 一.5 (2分)】49. 若X是二叉中序线索树中一个有左孩子地结点,且X不为根,则x地前驱为( )【南京理工大学1996 一.6 (2分)】A.X地双亲B.X地右子树中最左地结点C.X地左子树中最右结点D.X地左子树中最右叶结点50. 引入二叉线索树地目地是()A.加快查找结点地前驱或后继地速度 B.为了能在二叉树中方便地进行插入与删除C.为了能方便地找到双亲 D.使二叉树地遍历结果唯一【南京理工大学1998 一.5 (2分)】51. 线索二叉树是一种()结构.A.逻辑 B.逻辑和存储 C.物理 D.线性【西安电子科技大学1996 一.9 (2分)】52.n个结点地线索二叉树上含有地线索数为()A.2n B.n-l C.n+l D.n 【中山大学 1998 二.8 (2分)】53.()地遍历仍需要栈地支持.A.前序线索树 B.中序线索树 C.后序线索树【中科院计算所 1999一.1 (2分)】54.二叉树在线索后,仍不能有效求解地问题是().A.前(先)序线索二叉树中求前(先)序后继 B.中序线索二叉树中求中序后继C.中序线索二叉树中求中序前驱 D.后序线索二叉树中求后序后继【武汉大学2000 二.3 二.5】55. 设F是一个森林,B是由F变换得地二叉树.若F中有n个非终端结点,则B中右指针域为空地结点有()个.A. n-1 B.n C. n+1 D. n+2 【西安电子科技大学1998 一.10 (2分)】56.如果T2是由有序树T转换而来地二叉树,那么T中结点地后序就是T2中结点地().A.先序 B.中序 C.后序 D.层次序【西安电子科技大学1996 一.2 (2分)】57. 由3 个结点可以构造出多少种不同地有向树?()A.2 B.3 C.4 D.5 【北方交通大学 2001 一.6 (2分)】58.由3 个结点可以构造出多少种不同地二叉树?()A.2 B.3 C.4 D.5 【北方交通大学 2001 一.7 (2分)】59.下述二叉树中,哪一种满足性质:从任一结点出发到根地路径上所经过地结点序列按其关键字有序().A.二叉排序树 B.哈夫曼树 C.AVL树 D.堆【中国科技大学1998二.8(2分)】【中科院计算所1998二.8(2分)】60.在叶子数目和权值相同地所有二叉树中,最优二叉树一定是完全二叉树,该说法().A.正确 B.错误【中国科技大学1998 二.10(2分)】【中科院计算所1998 二.10(2分)】61.最优二叉树(哈夫曼树).最优查找树均为平均查找路径长度∑=niii hw1最小地树,其中对最优二叉树,n表示(1),对最优查找树,n表示(2),构造这两种树均(3).【中科院计算所1999一.3 (6分)】A.结点数 B.叶结点数 C.非叶结点数 D.度为2地结点数 E.需要一张n个关键字地有序表F.需要对n个关键字进行动态插入 G.需要n个关键字地查找概率表H.不需要任何前提62.下述编码中哪一个不是前缀码().【中科院计算所 2000 一.2 (2分)】A.(00,01,10,11) B.(0,1,00,11) C.(0,10,110,111) D.(1,01,000,001)63.下面几个符号串编码集合中,不是前缀编码地是().A.{0,10,110,1111} B.{11,10,001,101,0001} C.{00,010,0110,1000}D.{b,c,aa,ac,aba,abb,abc} 【西安电子科技大学2001 应用一.6(2分)】64. 当一棵有n个结点地二叉树按层次从上到下,同层次从左到右将数据存放在一维数组 A[l..n]中时,数组中第i个结点地左孩子为()【南京理工大学 1999一.18(2分)】A.A[2i](2i=<n) B. A[2i+1](2i+1=< n) C.A[i/2] D.无法确定65. 一棵有n个结点地二叉树,按层次从上到下,同一层从左到右顺序存储在一维数组A[1..n]中,则二叉树中第i个结点(i从1开始用上述方法编号)地右孩子在数组A中地位置是()A.A[2i](2i<=n) B.A[2i+1](2i+1<=n) C.A[i-2] D.条件不充分,无法确定【南京理工大学2000 一.4(1.5分)】66.从下列有关树地叙述中,选出5条正确地叙述(共5分) ()A.二叉树中每个结点有两个子结点,而树无此限制,因此二叉树是树地特殊情况.B.当K≥1时高度为K地二叉树至多有2k-1个结点.C.用树地前序周游和中序周游可以导出树地后序周游.D.线索二叉树地优点是便于在中序下查找前驱结点和后继结点.E.将一棵树转换成二叉树后,根结点没有左子树.F.一棵含有N个结点地完全二叉树,它地高度是ëLOG2Nû+1.G.在二叉树中插入结点,该二叉树便不再是二叉树.H.采用二叉树链表作树地存储结构,树地前序周游和其相应地二叉树地前序周游地结果样地.I.哈夫曼树是带权路径最短地树,路径上权值较大地结点离根较近.J.用一维数组存储二叉树时,总是以前序周游存储结点.【山东工业大学 1995三. (5分)】二.判断题1. 二叉树是度为2地有序树.【长沙铁道学院1997一.3(1分)】【中科院软件所1997一.9(1分)】2. 完全二叉树一定存在度为1地结点.【青岛大学 2002 一.4 (1分)】3. 对于有N个结点地二叉树,其高度为log2n.【上海海运学院 1998 一.6 (1分)】4.深度为K地二叉树中结点总数≤2k-1.【南京航空航天大学 1995 五.1 (1分)】5. 二叉树以后序遍历序列与前序遍历序列反映地同样地信息(他们反映地信息不独立).【华南理工大学2002一.7 (1分)】6. 二叉树地遍历结果不是唯一地.【南京理工大学 1997 二.8 (2分)】7. 二叉树地遍历只是为了在应用中找到一种线性次序.【青岛大学 2001 四.4 (1分)】8. 树可用投影法进行中序遍历. 【青岛大学 2002 一.6 (1分)】9. 一个树地叶结点,在前序遍历和后序遍历下,皆以相同地相对位置出现.【上海海运学院 1995 一.4 (1分)】10. 二叉树地前序遍历并不能唯一确定这棵树,但是,如果我们还知道该树地根结点是那一个,则可以确定这棵二叉树.【上海海运学院 1995 一.6 (1分)】11. 一棵一般树地结点地前序遍历和后序遍历分别与它相应二叉树地结点前序遍历和后序遍历是一致地.【上海海运学院 1996 一.6 (1分)】12.对一棵二叉树进行层次遍历时,应借助于一个栈.【南京航空航天大学 1995五.3 (1分)】13.用树地前序遍历和中序遍历可以导出树地后序遍历.【北京邮电大学 1999二.3 (2分)】14.采用二叉链表作存储结构,树地前序遍历和其相应地二叉树地前序遍历地结果是一样地.【北京邮电大学2000一.2(1分)】15. 用一维数组存储二叉树时,总是以前序遍历顺序存储结点.【上海海运学院1995 一.8 (1分)】16.中序遍历二叉链存储地二叉树时,一般要用堆栈;中序遍历检索二叉树时,也必须使用堆栈.【上海海运学院1998一.7(1分)】17.中序遍历一棵二叉排序树地结点就可得到排好序地结点序列【中科院软件所1999 六.1-1 (2分)】18. 后序线索二叉树是不完善地,要对它进行遍历,还需要使用栈.【长沙铁道学院 1998 一.2 (1分)】19.任何二叉树地后序线索树进行后序遍历时都必须用栈.【西安交通大学 1996 二.2 ( 3分) 】20.任何一棵二叉树都可以不用栈实现前序线索树地前序遍历.【西安交通大学1996 二.1 (3分)】21.由一棵二叉树地前序序列和后序序列可以唯一确定它.【中科院软件所 1997 一.3 (1分)】22.完全二叉树中,若一个结点没有左孩子,则它必是树叶.【东南大学 2001一.1-8(1分)】【中科院软件所1997一.2(1分)】【山东大学2001一.4 (1分)】23. 二叉树只能用二叉链表表示.【南京理工大学 1997 二.6 (2分)】24. 一棵有n个结点地二叉树,从上到下,从左到右用自然数依次给予编号,则编号为i地结点地左儿子地编号为2i(2i< n),右儿子是2i+1(2i+1<n).【南京理工大学 1997 二.11 (2分)】25. 给定一棵树,可以找到唯一地一棵二叉树与之对应.【青岛大学 2001 一.5 (1分)】26. 一棵树中地叶子数一定等于与其对应地二叉树地叶子数.【青岛大学 2002一.5 (1分)】27. 用链表(llink-rlink)存储包含n个结点地二叉树,结点地2n个指针区域中有n-1个空指针.【上海海运学院1996一.5(1分)】28. 二叉树中每个结点至多有两个子结点,而对一般树则无此限制.因此,二叉树是树地特殊情形.【上海海运学院1997一.5(1分)】29.树形结构中元素之间存在一个对多个地关系.【燕山大学 1998 二.1 (2分)】30.在二叉树地第i层上至少有2i-1个结点(i>=1).【燕山大学 1998 二.3 (2分)】31.必须把一般树转换成二叉树后才能进行存储.【南京航空航天大学 1997 一.4 (1分)】32.完全二叉树地存储结构通常采用顺序存储结构.【南京航空航天大学 1996 六.3 (1分)】33.将一棵树转成二叉树,根结点没有左子树;【北京邮电大学 1999 二.2 (2分)】34.在二叉树中插入结点,则此二叉树便不再是二叉树了.【北京邮电大学 2000 一.5 (1分)】35.二叉树是一般树地特殊情形.【北京邮电大学 2000 一.9 (1分) 2002 一.6 (1分)】36.树与二叉树是两种不同地树型结构.【东南大学 2001 一.1-7 (1分)】37. 非空地二叉树一定满足:某结点若有左孩子,则其中序前驱一定没有右孩子【合肥工业大学 2001 二.5 (1分)】38.在任意一棵非空二叉排序树,删除某结点后又将其插入,则所得二叉排序树与删除前原二叉排序树相同.【中科院软件所 1997 一.7 (1分)】39.度为二地树就是二叉树.【大连海事大学 2001 一.7 (1分)】40.深度为k具有n个结点地完全二叉树,其编号最小地结点序号为ë2k-2û+1.【东北大学 1997 二.3 (2分)】41.下面二叉树地定义只有一个是正确地,请在正确地地方画“√”.(1)它是由一个根和两株互不相交地.称为左子树和右子树地二叉树组成.(2)(a)在一株二叉树地级i上,最大结点数是2i-1(i≥1)(b)在一棵深度为k地二叉树中,最大结点数是2k-1+1(k≥1).(3)二叉树是结点地集合,满足如下条件:(a)它或者是空集;(b)或者是由一个根和两个互不相交地.称为左子树和右子树地二叉树组成.【中科院自动化所1995一.2(6分)】42. 在中序线索二叉树中,每一非空地线索均指向其祖先结点.【合肥工业大学2000 二.5 (1分)】43. 线索二叉树地优点是便于是在中序下查找前驱结点和后继结点.【上海海运学院1995 ,96,97 一.7(1分)】44. 二叉树中序线索化后,不存在空指针域.【青岛大学 2000 四.3 (1分)】45.霍夫曼树地结点个数不能是偶数.【北京邮电大学 2000 一.6 (1分)】46. 一棵哈夫曼树地带权路径长度等于其中所有分支结点地权值之和.【合肥工业大学2000二.4 (1分)】47. 哈夫曼树无左右子树之分.【青岛大学 2000 四.8 (1分)】48.当一棵具有n个叶子结点地二叉树地WPL值为最小时,称其树为Huffman树,且其二叉树地形状必是唯一地.【南京航空航天大学 1995 五.6 (1分)】49.哈夫曼树是带权路径长度最短地树,路径上权值较大地结点离根较近.【北京邮电大学 1999 二.5 (2分)】50. 用链表(llink-rlink)存储包含n个结点地二叉树时,结点地2n个指针区域中有n+1个空指针.( )【上海海运学院 1999 一.6(1分)】三.填空题1.二叉树由_(1)__,__(2)_,_(3)__三个基本单元组成.【燕山大学 1998 一.5 (3分)】2.树在计算机内地表示方式有_(1)__,_(2)__,_(3)__.【哈尔滨工业大学 2000 二.4 (3分)】3.在二叉树中,指针p所指结点为叶子结点地条件是______.【合肥工业大学1999 三.7(2分)】4.中缀式a+b*3+4*(c-d)对应地前缀式为__(1)_,若a=1,b=2,c=3,d=4,则后缀式db/cc*a-b*+地运算结果为_(2)__.【西南交通大学 2000 一.6】5.二叉树中某一结点左子树地深度减去右子树地深度称为该结点地____.【燕山大学1998一.9(1分)】6.具有256个结点地完全二叉树地深度为______.【燕山大学 1998 一.4 (1分)】7.已知一棵度为3地树有2个度为1地结点,3个度为2地结点,4个度为3地结点,则该树有______个叶子结点.【厦门大学 2000 六.2 (16%/3分)】8.深度为k地完全二叉树至少有___(1)____个结点,至多有___(2)____个结点.【厦门大学 2001 一.4 (14%/5分)】【南京理工大学 1999 二.5 (4分)】9.深度为H 地完全二叉树至少有_(1)__个结点;至多有_(2)__个结点;H和结点总数N之间地关系是 (3)__.【中科院计算所1998 一.3(3分)1999 二.4(3分)】【中国科技大学 1998 一.3(4分)】10.在顺序存储地二叉树中,编号为i和j地两个结点处在同一层地条件是______.【厦门大学 2002 六.3 (4分)】11.在完全二叉树中,编号为i和j地两个结点处于同一层地条件是______.【合肥工业大学 2000 三.6 (2分)】12.一棵有n个结点地满二叉树有__(1)_个度为1地结点.有__(2)_个分支(非终端)结点和__(3)_个叶子,该满二叉树地深度为_(4)__.【华中理工大学 2000 一.6 (3分))13.假设根结点地层数为1,具有n个结点地二叉树地最大高度是______.【北方交通大学 2001 二.1】14.在一棵二叉树中,度为零地结点地个数为N0,度为2地结点地个数为N2,则有N0 =______【北方交通大学 2001 二.6】【南京理工大学 1999 二.4 (2分)】15.设只含根结点地二叉树地高度为0,则高度为k地二叉树地最大结点数为______,最小结点数为______.【北京大学 1997 一.1 (4分)】16.设有N个结点地完全二叉树顺序存放在向量A[1:N]中,其下标值最大地分支结点为______.【长沙铁道学院 1997 二.3 (2分)】17.高度为K地完全二叉树至少有______个叶子结点.【合肥工业大学 1999 二.6(2分)】18.高度为8地完全二叉树至少有______个叶子结点.【合肥工业大学 2001 三.6(2分)】19.已知二叉树有50个叶子结点,则该二叉树地总结点数至少是______.【厦门大学 2002 六.4(4分)】20.一个有2001个结点地完全二叉树地高度为______.【南京理工大学 1997 三.2(1分)】21.设F是由T1,T2,T3三棵树组成地森林,与F对应地二叉树为B,已知T1,T2,T3地结点数分别为n1,n2和n3则二叉树B地左子树中有__(1)_个结点,右子树中有_(2)__个结点.【南京理工大学 2000 二.9(3分)】22.一个深度为k地,具有最少结点数地完全二叉树按层次,(同层次从左到右)用自然数依此对结点编号,则编号最小地叶子地序号是__(1)_;编号是i地结点所在地层次号是_(2)__(根所在地层次号规定为1层).【南京理工大学 2001 二.2(2分)】23.如某二叉树有20个叶子结点,有30个结点仅有一个孩子,则该二叉树地总结点数为______.【南京理工大学 2001 二.3(2分)】24.如果结点A有 3个兄弟,而且B是A地双亲,则B地度是______.【西安电子科技大学1999软件一.4(2分)】25.高度为h地2-3树中叶子结点地数目至多为______.【西安电子科技大学1999软件一.6(2分)】26.完全二叉树中,结点个数为n,则编号最大地分支结点地编号为______.【北京轻工业学院 2000 一.3 (2分)】27.设一棵完全二叉树叶子结点数为k,最后一层结点数>2,则该二叉树地高度为______.【北京科技大学 1998 一.3】28.对于一个具有n个结点地二元树,当它为一棵_(1)_二元树时具有最小高度,当它为一棵_(2)_时,具有最大高度.【哈尔滨工业大学 2001 一.3 (2分)】29.具有N个结点地二叉树,采用二叉链表存储,共有______个空链域.【重庆大学2000 一.8】30.8层完全二叉树至少有______个结点,拥有100个结点地完全二叉树地最大层数为______.【西南交通大学 2000 一.1】31.含4个度为2地结点和5个叶子结点地二叉树,可有______个度为1地结点.【北京工业大学 2001 一.6 (2分)】32.一棵树T中,包括一个度为1地结点,两个度为2地结点,三个度为3地结点,四个度为4地结点和若干叶子结点,则T地叶结点数为______.【山东大学 2001 三.2 (2分)】33. n(n大于1)个结点地各棵树中,其深度最小地那棵树地深度是_(1)__.它共有_(2)__个叶子结点和_(3)__个非叶子结点,其中深度最大地那棵树地深度是_(4)__,它共有_(5)__个叶子结点和_(6)__个非叶子结点.【山东大学 2001 三.7 (2分)】34.每一棵树都能唯一地转换为它所对应地二叉树.若已知一棵二叉树地前序序列是BEFCGDH,对称序列是FEBGCHD,则它地后序序列是_(1)__.设上述二叉树是由某棵树转换而成,则该树地先根次序序列是_(2)__.【山东工业大学 1997 二. (6分)】35.先根次序周游树林正好等同于按_(1)__周游对应地二叉树,后根次序周游树林正好等同于按__(2)_周游对应地二叉树.【山东工业大学 1999 二.1 (4分)】36.二叉树结点地对称序序列为A,B,C,D,E,F,G,后序序列为B,D,C,A,F,G,E,则该二叉树结点地前序序列为_(1)__,则该二叉树对应地树林包括_(2)__棵树.【北京大学 1997 一.2 (4分)】37.二叉树地先序序列和中序序列相同地条件是______.【合肥工业大学 2000 三.7(2分)】38.已知一棵二叉树地前序序列为abdecfhg,中序序列为dbeahfcg,则该二叉树地根为_(1)__,左子树中有_(2)__, 右子树中有_(3)__.【南京理工大学 1996 二.1(6分)】39.设二叉树中每个结点均用一个字母表示,若一个结点地左子树或右子树为空,用.表示,现前序遍历二叉树,访问地结点地序列为ABD.G...CE.H..F..,则中序遍历二叉树时,访问地结点序列为_(1)__;后序遍历二叉树时,访问地结点序列为_(2)__.【南京理工大学 1999 二.3(4分)】40.已知二叉树前序为ABDEGCF,中序为DBGEACF,则后序一定是____.【青岛大学2000 六.3(2分)】41.现有按中序遍历二叉树地结果为abc,问有_(1)__种不同地二叉树可以得到这。
第6章-数据结构习题题目及答案-树和二叉树-参考答案
第6章-数据结构习题题目及答案-树和二叉树-参考答案一、基础知识题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=86.2一棵完全二叉树上有1001个结点,求叶子结点的个数。
【解答】因为在任意二叉树中度为2的结点数n2和叶子结点数n0有如下关系:n2=n0-1,所以设二叉树的结点数为n,度为1的结点数为n1,则n=n0+n1+n2n=2n0+n1-11002=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个结点仅有一个孩子,则该二叉树的总结点数是多少。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
一、选择题
1、设T是一棵树,T’是对应于x的二叉树,则T的先根次序遍历和T’的()次序遍历相同。
A、先根
B、中根
C、后根
D、以上都不是
2、
3、若二叉树的后序遍历序列为dabec,中序遍历序列为debac,则前序序列遍历为()。
A、acbed
B、decab
C、deabc
D、cedba
4、具有35个结点的完全二叉树的深度为()
A、5
B、6
C、7
D、8
5、将一棵有100个结点的完全二叉树从上到下,从左到右依次对结点进行编号,根结点的编号为1,则编号为49的结点的左孩子结点编号为()
A、98
B、99
C、50
D、48
6、某二叉树的前序和后序序列正好相反,则该二叉树一定是()的二叉树。
A、空或只有一个结点
B、高度等于其结点数
C、任一结点无左孩子
D、任一结点无左孩子
7、二叉树在线索化后,仍不能有效求解的问题是()
A、先根线索二叉树中求先根后继
B、中根线索二叉树中求中根后继
C、中根线索二叉树中求中根前驱
D、后根线索二叉树中求后根后继
8、在线索化二叉树中,t所指结点没有左子树的充足条件是()
A、t-lchild==NULL
B、t->ltag==1
C、t->ltag==1&&t->lchild==NULL
D、以上都不对
9、设高度为h的二叉树上只有度为0和度为2的结点,则此类二叉树中所包含的结点数至少为()
A、2h
B、2h-1
C、2h+1
D、h+1
10、深度为5的二叉树至多有()个结点。
A、16
B、32
C、31
D、10
11、在一非空二叉树的中序遍历序列中,根结点的右边()
A、只有右子树上的所有结点
B、只有右子树上的部分结点
C、只有左子树上的所有结点
D、只有左子树上的部分结点
12、树最适合用来表示()
A、有序数据元素
B、无序数据元素
C、元素之间具有分支层次关系的数据
D、元素之间无联系的数据
13、任何一棵二叉树的叶结点在先序、中序和后序遍历序列中的相对次序()
A、不发生改变
B、发生改变
C、不能确定
D、以上都不对
14、设n,m为一棵二叉树上的两个结点,在中序遍历时,n在m前的条件是()
A、n在m右方
B、n是m祖先
C、n在m左方
D、n是m子孙
15、线索二叉树是一种()结构
A、逻辑
B、逻辑和存储
C、物理
D、线性
16、森林的后根遍历序列与其对应二叉树的()遍历序列一致。
A、先根
B、后根
C、中根
D、不可能
二、填空题
1、由一棵二叉树后序序列和(中序)可唯一确定这棵二叉树。
2、含有n个结点的二叉树用二叉链表表示时,有(N+1)个空链域。
3、有m个叶子结点的哈夫曼树有(2*M-1)个结点。
4、前序为a,b,c且后序c,b,a的二叉树共有(4)棵。
5、已知完全二叉树的第4层有6个结点,则其叶子结点数是(7)。
6、已知二叉树有31个叶子结点,且仅有一个孩子的结点数为40,则总结点数为(101)。
7、树和二叉树的两个主要差别是(二叉树是有序树)和(二叉树的度最大为2)。
8、从概念上讲,树与二叉树是两种不同的数据结构,将树转化成二叉树的基本目的是(通过与树对应的二叉树的操作来实现树的操作)。
9、深度为k的完全二叉树至少有(2k-1)个结点,至多有(2k-1)个结点,若按自上而下,从左至右的次序给结点编号从1开始,则编号最小的叶子结点的编号是(2k-1)。
10、结点最少的树为(空树),结点最少的二叉树是(空二叉树)。
12、以数据集(4,5,6,7,10,12,18)为结点权值的Huffman树的带权路径长度为(168)。
(可画出图形)。