画出对长度为10的有序表进行折半查找的判定树_第1页
画出对长度为10的有序表进行折半查找的判定树_第2页
画出对长度为10的有序表进行折半查找的判定树_第3页
全文预览已结束

下载本文档

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

文档简介

1、第九章 查找作业:9.3 9.8 9.31 9.33=9.3 画出对长度为10的有序表进行折半查找的判定树,并求其等概率时查找成功的平均查找长度。参考答案:等概率查找时查找成功的平均查找长度为ASL=(1*1+2*2+3*4+4*3)/10 =2.99.8 已知含12个关键字的有序表及其相应权值为:关键字ABCDEFGHIJKL权值823493267114 (1)试按次优查找树的构造算法并加适当调整画出由这12个关键字构造所得的次优查找树,并计算它的PH值;(2)画出对以上有序表进行折半查找的判定树,并计算它的PH值。参考答案:(1) 次优查找树如下所示,其PH值为133;EIAHLCJFBD

2、KG(2) 折半查找的判定树的PH值为156。对BCD调整后的次优查找树:其PH值为134ADCB对次优查找树的调整操作的分析(以下摘自刘文予老师回复邮件)分析:什么是次最优并没有一个严格的定义,与我们的实际工程的要求有关。1. 调整是必须的,否则按书上算法9.3的构造方法构造的查找树离次最优有距离,但是,调整的工作量不能太大,否则,我们可以直接构造最优查找树(用次最优查找树是为了降低构造最优查找树的时间复杂度),显然调整的结果与最优查找树的误差精度与时间复杂度有关,精度越高,时间复杂度越大。书上所说的“适当”比较模糊,没有统一的说法,根据实际的要求选择一个“适当”的调整标准。2. 书上的参考

3、答案是133,非唯一的标准答案,134也是可取的答案。它是只对根结点进行调整,而书上的方法是对所有的子树的根结点进行调整,显然书上的方法精度更优,但是时间复杂度增大,具体,结果134的方法是O(log2n),书上的方法是O(n*log2n),但我们注意构造次最优查找树的时间复杂度是O(n*log2n),即我们对所有的子树的根结点进行调整不会增加构造算法的时间复杂度(会增加一些时间,如增加30),说明对所有的子树的根结点进行调整是可行的。需强调一点,两种方法都是正确的,没有标准的答案。 检验自己得到的PH值究竟是不是最小没有意义,最小是最优查找树,已证明不可能在O(n*log2n)的复杂度下构造

4、出。同理,精确的判知哪一步调整哪一步不调整也是没有意义的,我们已有最优的构造算法。但是我们可以讨论几种常用的调整方法以及他们的特点。3. 我的一些想法 a)数据结构中的一些问题没有标准答案,需要根据具体的要求进行设计,很多算法时间和空间复杂度是相互制约的,一个减小,另一个会增大,这就需要我们根据实际的情况进行综合设计和平衡。这也是数据结构课程的特点。 b)算法的复杂度是非常重要的,否则,你不能得出正确的分析结果。 c)除了上面的2种调整方法,我还可以提出一种新的方法,把根结点与查找树中的最大PH值结点调整一次,他的时间复杂度是O(n),介于2种方法之间,他的精度是否在2者之间呢?你可以研究一下

5、。 d)学生提的问题很好,如果不是已解答,可以作为考试题让他们分析,我们缺乏这类分析问题的题目!9.31 试写一个判别给定二叉树是否为二叉排序树的算法,设此二叉树以二叉链表作存储结构。且树中结点的关键字均不同。分析:注意仔细研究二叉排序树的定义。易犯的典型错误是按下述思路进行判别:“若一棵非空的二叉树其左、右子树均为二叉排序树,且左子树的根的值小于根结点的值,又根结点的值不大于右子树的根的值,则是二叉排序树。” 假如你准备写递归形式的算法,则建议你采用如下所述的函数首部,bool BiSortTree(BiTree T, BiTree &PRE)其中PRE为指向当前访问结点的前驱的指针。参考程

6、序:int flag=1, last=NULL; int Is_BSTree(Bitree T)/判断二叉树T是否二叉排序树,是则返回1,否则返回0if(T-lchild&flag) Is_BSTree(T-lchild);if(T-datadata;if(T-rchild&flag) Is_BSTree(T-rchild);return flag;/Is_BSTree 9.33 编写递归算法,从大到小输出给定二叉排序树中所有关键字不小于x的数据元素。要求你的算法的时间复杂度为O(logn+m),其中n为排序树中所含结点数,m为输出的关键字个数。分析:为满足题目所要求的时间复杂度,算法中应注意做到,一旦访问到关键字小于x的结点,立即结束遍历。参考程序: void Print_NLT(BiTree T,int x)/从大到小输出二叉排序树T中所有不小于x的元素 if(T-rchil

温馨提示

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

评论

0/150

提交评论