数据结构树的测试题_第1页
数据结构树的测试题_第2页
数据结构树的测试题_第3页
数据结构树的测试题_第4页
数据结构树的测试题_第5页
已阅读5页,还剩7页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、习题六树和二叉树一、单项选择题以下说法错误的是(A )树形结构的特点是一个结点可以有多个直接前趋线性结构中的一个结点至多只有一个直接后继树形结构可以表达(组织)更复杂的数据树(及一切树形结构)是一种”分支层次”结构任何只含一个结点的集合是一棵树下列说法中正确的是(D)任何一棵二叉树中至少有一个结点的度为2任何一棵二叉树中每个结点的度都为2任何一棵二叉树中的度肯定等于2任何一棵二叉树中的度可以小于2讨论树、森林和二叉树的关系,目的是为了(入)借助二叉树上的运算方法去实现对树的一些运算将树、森林按二叉树的存储方式进行存储将树、森林转换成二叉树体现一种技巧,没有什么实际意义树最适合用来表示(C )A

2、.有序数据元素B.无序数据元素C.元素之间具有分支层次关系的数据D.元素之间无联系的数据若一棵二叉树具有10个度为2的结点,5个度为1的结点,则度为0的结点个数是(B )A. 9B. 11C. 15 D.不确定设森林F中有三棵树,第一,第二,第三棵树的结点个数分别为M1, M2和M3。与 森林F对应的二叉树根结点的右子树上的结点个数是(D )。A. M1B. M1+M2 C. M3D. M2+M3一棵完全二叉树上有1001个结点,其中叶子结点的个数是(E )A. 250 B. 500 C. 254 D. 505 E.以上答案都不对8 .二叉树的第I层上最多含有结点数为(C )A. 2iB. 2

3、i-1-1C. 2i-1D. 2i -1一棵二叉树高度为h,所有结点的度或为0,或为2,则这棵二叉树最少有(B )结点A. 2h B. 2h-1 C. 2h+1D. h+1利用二叉链表存储树,则根结点的右指针是(B )。A.指向最左孩子B.指向最右孩子C.空 D.非空已知一棵二叉树的前序遍历结果为ABCDEF,中序遍历结果为CBAEDF,则后序遍历的 结果为(A )。A. CBEFDA B. FEDCBA C. CBEDFA 。.不定已知某二叉树的后序遍历序列是dabec,中序遍历序列是debac ,它的前序遍历是 (D )。A.acbed B.decab C.deabc D.cedba在二叉

4、树结点的先序序列,中序序列和后序序列中,所有叶子结点的先后顺序(B )A.都不相同B.完全相同C.先序和中序相同,而与后序不同 D.中序和后序相同,而与先序不同在完全二叉树中,若一个结点是叶结点,则它没(C )。A.左子结点B.右子结点C.左子结点和右子结点D.左子结点,右子结点和兄弟结点20.由3个结点可以构造出多少种不同的二叉树? ( D )A. 2 B. 3C. 4D. 522. 一棵有n个结点的二叉树,按层次从上到下,同一层从左到右顺序存储在一维数组 A1.n中,则二叉树中第i个结点(i从1开始用上述方法编号)的右孩子在数组A中的位 置是(D )A. A2i(2i=n)B. A2i+1

5、(2i+1lchild=null & p-rchlid=null(1)2k-1(2)2k-1 TOC o 1-5 h z 642n n-1n+1先序遍历后序遍历中序遍历(1)2k-2+1 (第k层1个结点,总结点个数是2H-1,其双亲是2H-1/2=2k-2) elog2iu+14任何结点至多只有右子女的二叉树。二叉排序树前序11.69*count+, countleaf(l-rchile,count)(1) p=p-lchild / 沿左子树向下(2) p=p-rchild(1)0(2) hlhr(3)hr=hl(1)p-rchild (2)p-lchild (3)p-lchildADDQ(

6、Q,p-lchild) (5)ADDQ(Q,p-rchild)四、应用题1.树和二叉树逻辑上都是树形结构,树和二叉树的区别有三:一是二叉树的度至多为2, 树无此限制;二是二叉树有左右子树之分,即使在只有一个分枝的情况下,也必须指出是 左子树还是右子树,树无此限制;三是二叉树允许为空,树一般不允许为空(个别书上允许 为空)。二叉树不是树的特例。【解答】具有3个结点的二叉树具有3个结点的树3.4.解答:先根序列:A B C D E F G H I J;中根序列:B C D A F E H J I G;后根序列:D C B F J I H G E A。kh-1(h 为层数)因为该树每层上均有Kh-1

7、个结点,从根开始编号为1,则结点i的从右向左数第2 个孩子的结点编号为ki。设n为结点i的子女,则关系式(i-1)k+2=n1)的前一结点编号为n-1 (其最右边子女编号是(n-1)*k+1),故结点n 的第i个孩子的编号是(n-1)*k+1+i。根据以上分析,结点n有右兄弟的条件是,它不是双亲的从右数的第一子女,即 (n-1)%k!=0,其右兄弟编号是n+1。5.(l)图略;前序序列:ABCEDFHGIJ中序序列:E C B H F D J I G A后序序列:ECHFJIGDBA图略。字符A,B,C,D出现的次数为9,1,5,3。其哈夫曼编码如下A:1,B:000,C:01,D:001五、

8、算法设计题1.题目分析二叉树是递归定义的,以递归方式建立最简单。判定是否是完全二叉树,可 以使用队列,在遍历中利用完全二叉树“若某结点无左子女就不应有右子女”的原则进行判 断。BiTree Creat()/建立二叉树的二叉链表形式的存储结构ElemType x; BiTree bt;scanf(d”,&x); /本题假定结点数据域为整型if(x=0) bt=null;else if(x0)bt=(BiNode *)malloc(sizeof (BiNode);bt-data=x; bt-lchild=creat(); bt-rchild=creat();else error(“输入错误”);r

9、eturn (bt);/结束 BiTreeint JudgeComplete(BiTree bt) 判断二叉树是否是完全二叉树,如是,返回1,否 贝IJ,返回0int tag=0; BiTree p=bt, Q; / Q是队列,元素是二叉树结点指针,容量足 够大if(p=null) return (1);QueueInit(Q); QueueIn(Q,p); /初始化队列,根结点指针入队 while (!QueueEmpty(Q)p=QueueOut(Q);出队if (p-lchild & !tag) QueueIn(Q,p-lchild); /左子女入队 else if (p-lchild)

10、 return 0;前边已有结点为空,本结点不空else tag=1;/首次出现结点为空if (p-rchild & !tag) QueueIn(Q,p-rchild); /右子女入队 else if (p-rchild) return 0; else tag=1; /whilereturn 1; /JudgeComplete算法讨论完全二叉树证明还有其它方法。判断时易犯的错误是证明其左子树和右子数 都是完全二叉树,由此推出整棵二叉树必是完全二叉树的错误结论。题目分析后序遍历最后访问根结点,即在递归算法中,根是压在栈底的。采用后序非递 归算法,栈中存放二叉树结点的指针,当访问到某结点时,栈中所

11、有元素均为该结点的祖先。 本题要找p和q的最近共同祖先结点r ,不失一般性,设p在q的左边。后序遍历必然先遍 历到结点p,栈中元素均为p的祖先。将栈拷入另一辅助栈中。再继续遍历到结点q时, 将栈中元素从栈顶开始逐个到辅助栈中去匹配,第一个匹配(即相等)的元素就是结点p和 q的最近公共祖先。typedef structBiTree t;inttag;/tag=0表示结点的左子女已被访问,tag=1表示结点的右子女已被 访问stack;stack s,s1;/栈,容量够大BiTree Ancestor(BiTree ROOT,p,q,r)/俅二叉树上结点p和q的最近的共同祖先结点r。 top=0;

12、 bt=ROOT;while(bt!=null |top0)while(bt!=null & bt!=p & bt!=q)/结点入栈s+top.t=bt; stop.tag=0; bt=bt-lchild; /沿左分枝向下if(bt=p) 不失一般性,假定p在q的左侧,遇结点p时,栈中元素均为p的祖先结点for(i=1;i0;i-)/;将栈中元素的树结点到si去匹配pp=si.t;for (j=top1;j0;j-)if(s1j.t=pp) printf(p 和 q 的最近共同的祖先已找到”);return (pp); while(top!=0 & stop.tag=1) top-; 退栈if

13、 (top!=0) stop.tag=1;bt=stop.t-rchild; /沿右分枝向下遍历/ 结束 while(bt!=null |top0)return(null);/ q、p 无公共祖先 结束 Ancestor解答:本算法要借用队列来完成,其基本思想是,只要队列不为空,就出队列,然后判 断该结点是否有左孩子和右孩子,如有就依次输出左、右孩子的值,然后让左、右孩子进队 列。void layorder (bitreptr T)/*队列初始化*/initqueue (q)if(T!=NULL)/*入队列*/*若队列非空*/*出队*/printf(%f”,T-data);enqueue (q

14、, T);while (not emptyqueue (q)outqueue (q, p);if (p-lchild!=NULL)printf(f”,p-lchild-data);/*入队列*/enqueue (q, p-lchild);if (p-rchild!=NULL)printf(%”,p-rchild-data);/*入队列*/enqueue (q, p-rchild);【解答】Void PreOrder(BiTree root)/*先序遍历二叉树的非递归算法*/InitStack(&S);p=root;while(p!=NULL | !IsEmpty(S) if(p!=NULL)V

15、isit(p-data);push(&S,p);p=p-Lchild;elsePop(&S,&p);p=p-RChild;void InOrder(BiTree bt)BiTree s,p=bt; /s是元素为二叉树结点指针的栈,容量足够大int top=0;while(p | top0)while(p) s+top=p; bt=p-lchild;/中序遍历左子树if(top0)p=stop-; printf(p-data); p=p-rchild; /退栈,访问,转右子树BiTree Copy(BiTree t)/复制二叉树tBiTree bt;if (t=null) bt=null;els

16、ebt=(BiTree)malloc(sizeof (BiNode); bt-data=t-data;bt-lchild=Copy(t-lchild);bt-rchild=Copy(t-rchild);return(bt); /结束 Copy题目分析叶子结点只有在遍历中才能知道,这里使用中序递归遍历。设置前驱结点指针 pre,初始为空。第一个叶子结点由指针head指向,遍历到叶子结点时,就将它前驱的rchild 指针指向它,最后叶子结点的rchild为空。LinkedList head,pre=null; /全局变量LinkedList InOrder(BiTree bt)/中序遍历二叉树bt

17、,将叶子结点从左到右链成一个单链表,表头指针为headif(bt)InOrder(bt-lchild);/中序遍历左子树if(bt-lchild=null & bt-rchild=null) /叶子结点if(pre=null) head=bt; pre=bt; /处理第一个叶子结点 elsepre-rchild=bt; pre=bt; /将叶子结点链入链表InOrder(bt-rchild);/中序遍历左子树pre-rchild=null;设置链表尾return (head); /InOrder时间复杂度为O(n),辅助变量使用head和pre,栈空间复杂度O(n)题目分析删除以元素值x为根的

18、子树,只要能删除其左右子树,就可以释放值为x的 根结点,因此宜采用后序遍历。删除值为x结点,意味着应将其父结点的左(右)子女指针置 空,用层次遍历易于找到某结点的父结点。本题要求删除树中每一个元素值为x的结点的 子树,因此要遍历完整棵二叉树。void DeleteXTree(BiTree bt) /删除以 bt 为根的子树DeleteXTree(bt-lchild); DeleteXTree(bt-rchild);/删除 bt 的左子树、右子树 free(bt); / DeleteXTree/释放被删结点所占的存储空间void Search(B:Tree bt,ElemType x)/在二叉树

19、上查找所有以x为元素值的结点,并删除以其为根的子树BiTree Q;/Q是存放二叉树结点指针的队列,容量足够大迁(bt)if(bt-data=x) DeleteXTree(bt); exit(0);/若根结点的值为 x,则删除整棵树 QueueInit(Q); QueueIn(Q,bt);while(!QueueEmpty(Q)p=QueueOut(Q);if(p-lchild)/若左子女非空if(p-lchild-data=x)/左子女结点值为x,应删除当前结点的左子树DeleteXTree(p-lchild); p-lchild=null; /父结点的左子女置空 else Enqueue

20、(Q,p-lchild);/ 左子女入队列if(p-rchild)/若右子女非空if(p-rchild-data=x)右子女结点值为x,应删除当前结点的右子树DeleteXTree(p-rchild); p-rchild=null; /父结点的右子女置空 else Enqueue (Q,p-rchild);/ 右子女入队列/while/if(bt) /searchint BTLC(BiTree T,int *c)/对二叉树 T 的结点计数if(T)*c+;BTLC(T-lchild,&c); /统计左子树结点 BTLC(T-rchild,&c); /统计右子树结点 /结束Count,调用时*c=010.找结点的中序前驱结点BiTNode *

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论