7-第七章.ppt
《7-第七章.ppt》由会员分享,可在线阅读,更多相关《7-第七章.ppt(45页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、第九章 查找n查找也叫检索,是根据给定的某个值,在表中确定一个关键字等于给定值的记录或数据元素n关键字是数据元素中某个数据项的值,它可以标识一个数据元素n查找方法评价o查找速度o占用存储空间多少o算法本身复杂程度o平均查找长度ASL(Average Search Length):为确定记录在表中的位置,需和给定值进行比较的关键字的个数的期望值叫查找算法的o9.1 顺序查找n查找过程:从表的一端开始逐个进行记录的关键字和给定值的比较n算法描述Ch7_1.ci例 0 1 2 3 4 5 6 7 8 9 10 11 5 13 19 21 37 56 64 75 80 88 92找6464监视哨iii
2、i比较次数=5比较次数:查找第n个元素:1查找第n-1个元素:2.查找第1个元素:n查找第i个元素:n+1-i查找失败:n+1n顺序查找方法的ASLo9.2 折半查找n查找过程:每次将待查记录所在区间缩小一半n适用条件:采用顺序存储结构的有序表n算法实现o设表长为n,low、high和mid分别指向待查元素所在区间的上界、下界和中点,k为给定值o初始时,令low=1,high=n,mid=(low+high)/2o让k与mid指向的记录比较n若k=rmid.key,查找成功n若krmid.key,则low=mid+1o重复上述操作,直至lowhigh时,查找失败n算法描述lowhighmid例
3、 1 2 3 4 5 6 7 8 9 10 115 13 19 21 37 56 64 75 80 88 92找211 2 3 4 5 6 7 8 9 10 115 13 19 21 37 56 64 75 80 88 92lowhighmid1 2 3 4 5 6 7 8 9 10 115 13 19 21 37 56 64 75 80 88 92lowhighmidCh7_2.c例 1 2 3 4 5 6 7 8 9 10 115 13 19 21 37 56 64 75 80 88 92lowhighmid找701 2 3 4 5 6 7 8 9 10 115 13 19 21 37 5
4、6 64 75 80 88 92lowhighmid1 2 3 4 5 6 7 8 9 10 115 13 19 21 37 56 64 75 80 88 92low highmid1 2 3 4 5 6 7 8 9 10 115 13 19 21 37 56 64 75 80 88 92lowhighmid1 2 3 4 5 6 7 8 9 10 115 13 19 21 37 56 64 75 80 88 92lowhigh1185210741936判定树:1 2 3 4 5 6 7 8 9 10 115 13 19 21 37 56 64 75 80 88 92n算法评价o判定树:描述查
5、找过程的二叉树叫o有n个结点的判定树的深度为log2n+1o折半查找法在查找过程中进行的比较次数最多不超过其判定树的深度o折半查找的ASLo9.3 分块查找n查找过程:将表分成几块,块内无序,块间有序;先确定待查记录所在块,再在块内查找n适用条件:分块有序表n算法实现o用数组存放待查记录,每个数据元素至少含有关键字域o建立索引表,每个索引表结点含有最大关键字域和指向本块第一个结点的指针n算法描述Ch7_3.c1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 1822 12 13 8 9 20 33 42 44 38 24 48 60 58 74 57 86 5
6、322 48 861 7 13索引表查38查找过程:(1)先确定待查记录所在的块(子表)(2)然后在块中顺序查找n分块查找方法评价ASL最大最小两者之间表结构有序表、无序表 有序表分块有序表存储结构顺序存储结构线性链表顺序存储结构 顺序存储结构线性链表查找方法比较顺序查找折半查找分块查找9.4 二叉排序树o定义:二叉排序树或是一棵空树,或是具有下列性质的二叉树:n若它的左子树不空,则左子树上所有结点的值均小于它的根结点的值n若它的右子树不空,则右子树上所有结点的值均大于或等于它的根结点的值n它的左、右子树也分别为二叉排序树o二叉排序树的插入n插入原则:若二叉排序树为空,则插入结点应为新的根结点
7、;否则,继续在其左、右子树上查找,直至某个叶子结点的左子树或右子树为空为止,则插入结点应为该叶子结点的左孩子或右孩子n二叉排序树生成:从空树出发,经过一系列的查找、插入操作之后,可生成一棵二叉排序树n插入算法例 10,18,3,8,12,2,7,310101810183101838101838 12101838 122101838 1227101838 12273中序遍历二叉排序树可得到一个关键字的有序序列相等的时候走右边!Ch5_9.co二叉排序树的删除要删除二叉排序树中的p结点,分三种情况:np为叶子结点np只有左子树或右子树np左、右子树均非空SQPLP中序遍历:Q S PL PSQPL
8、中序遍历:Q S PL(2)SPPLQ中序遍历:PL P S QSPLQ中序遍历:PL S Q(1)中序遍历:P PR S QSPRQ中序遍历:PR S Q(3)SPPRQ中序遍历:Q S P PRSQPR中序遍历:Q S PR(4)SQPRPFPCPRCLQQLSSL中序遍历:CL C QL Q SL S P PR FFSCPRCLQQLSL中序遍历:CL C QL Q SL S PR F(5)FPCPRCL中序遍历:CL C P PR FFCPRCL中序遍历:CL C PR F(6)n删除算法例805012060110150557053删除508060120110150557053删除60
9、805512011015053701042581354删除1084255134删除58425413Ch5_10.c二叉排序树查找的性能分析二叉排序树查找的性能分析 在二叉排序树查找中,成功的查找次数不会超过二叉树的深度,而具有n个结点的二叉排序树的深度,最好为log2n,最坏为n。因此,二叉排序树查找的最好时间复杂度为O(log2n),最坏的时间复杂度为O(n),一般情形下,其时间复杂度大致可看成O(log2n),比顺序查找效率要好,但比二分查找要差。平衡二叉树平衡二叉树1平衡二叉树的概念平衡二叉树的概念 平衡二叉树(balanced binary tree)是由阿德尔森一维尔斯和兰迪斯(Ad
10、elson-Velskii and Landis)于1962年首先提出的,所以又称为AVL树。若一棵二叉树中每个结点的左、右子树的深度之差的绝对值不超过1,则称这样的二叉树为平衡二叉树。将该结点的左子树深度减去右子树深度的值,称为该结点的平衡因子(balance factor)。也就是说,一棵二叉排序树中,所有结点的平衡因子只能为0、1、-1时,则该二叉排序树就是一棵平衡二叉树,否则就不是一棵平衡二叉树。2.非平衡二叉树的平衡处理 若一棵二叉排序树是平衡二叉树,插入某个结点后,可能会变成非平衡二叉树,这时,就可以对该二叉树进行平衡处理,使其变成一棵平衡二叉树。处理的原则应该是处理与插入点最近的
11、、而平衡因子又比1大或比-1小的结点。下面将分四种情况讨论平衡处理。(1)LL型型 的处理的处理(左左型左左型)如图8-10所示,在A的左孩子B上插入一个左孩子结点C,使A的平衡因子由1变成了2,成为不平衡的二叉树序树。这时的平衡处理为:将A顺时针旋转,成为B的右子树,而原来B的右子树则变成A的左子树,待插入结点C作为B的左子树。(注:图中结点旁边的数字表示该 结点的平衡因子)(2)LR型的处理型的处理(左右型左右型)如图8-11所示,在A的左孩子B上插入一个右孩子C,使的A的平衡因子由1变成了2,成为不平衡的二叉排序树。这是的平衡处理为:将C变到B与A 之间,使之成为LL型,然后按第(1)种
12、情形LL型处理。(3)RR型的处理型的处理(右右型右右型)如图8-12所示,在A的右孩子B上插入一个右孩子C,使A的平衡因子由-1变成-2,成为不平衡的二叉排序树。这时的平衡处理为:将A逆时针旋转,成为B的左子树,而原来B的左子树则变成A的右子树,待插入结点C成为B的右子树。(4)RL型的处理型的处理(右左型右左型)如 图8-13所示,在A的右孩子B上插入一个左孩子C,使A的平衡因子由-1变成-2,成为不平衡的二叉排序树。这时的平衡处理为:将C变到A与B之间,使之成为RR型,然后按第(3)种情形RR型处理。例8-2,给定一个关键字序列4,5,7,2,1,3,6,试生成一棵平衡二叉树。分析:平衡
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 第七
限制150内