动态搜索结构_第1页
动态搜索结构_第2页
动态搜索结构_第3页
动态搜索结构_第4页
动态搜索结构_第5页
已阅读5页,还剩27页未读 继续免费阅读

下载本文档

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

文档简介

1、马强2015年4月4日大纲2 二叉搜索树二叉搜索树定义每个节点有一个唯一的key值,且所有结点互不相同左子树所有key值小于根的key值右子树所有key值大于根的key值左右子树都是二叉搜索树12225030011020099105230216二叉搜索树又称为二叉搜索树又称为“二叉排序树二叉排序树”、“二叉查找树二叉查找树”、“二叉检索树二叉检索树”3二叉搜索树的基本操作查找插入删除4二叉搜索树查找操作 与根结点的key值比较相等则 查找成功小于则查找左子树大于则查找右子树13 85231837如何查找元素如何查找元素 5 ?555查找成功!查找成功!5二叉搜索树插入操作 首先执行查找算法,找

2、出将要插入结点的父亲结点首先执行查找算法,找出将要插入结点的父亲结点 判断被插结点是其父亲结点的左或右孩子。将被插判断被插结点是其父亲结点的左或右孩子。将被插结点作为叶子结点插入。结点作为叶子结点插入。 若二叉树为空。作为根结点。若二叉树为空。作为根结点。6二叉搜索树插入操作利用插入操作可以构造一棵二叉搜索树利用插入操作可以构造一棵二叉搜索树首先给出结点序列首先给出结点序列:13、8、23、5、18、37 13537 18 8238 2355181837377二叉搜索树删除操作情况1 叶子结点:直接删除,更改它的父亲结点的相应指针域为空。叶子结点:直接删除,更改它的父亲结点的相应指针域为空。如

3、:删除值为如:删除值为 15、70 的结点。的结点。156070302050603020508二叉搜索树删除操作情况212225030011020099105230400450500若被删结点只有一个孩子结点。则用它的子树代替它。若被删结点只有一个孩子结点。则用它的子树代替它。如删除结点的关键值为如删除结点的关键值为 99 结点。结点。被删结点被删结点1222503002002304004505001101059二叉搜索树删除操作情况3被删结点左右孩子都不为空选取“替身”取代被删结点。然后删除替身结点如何选择替身?左子树中最大的结点或 右子树中最小的结点10122250300110200991

4、05330400450500被删结点被删结点替替身身11025030010520099330400450500将替身的数据复制到被删结点的数据。将替身的数据复制到被删结点的数据。删除值为删除值为122的结点。的结点。110二叉搜索树删除操作情况311 12225030011020099105330400450500被删结点被删结点替替身身将替身的数据场复制到被删结点的数据场。将替身的数据场复制到被删结点的数据场。删除值为删除值为122的结点。的结点。 20025030011099105400450500330200二叉搜索树删除操作情况312二叉搜索树的性能查找:从根节点向下扫描到叶子结点。O

5、(h)插入和删除:先查找、再操作。所以也是O(h)与树的高度密切相关20025030011099105400450500330主要用于内存中目录的编制要求能够快速的查找、插入删除13二查搜索树的高度 输入顺序为输入顺序为 4、5、6、7、8 4 5 6 7 8 7 5 8 4 6 输入顺序为输入顺序为 7、5、4、6、8 最坏情况为n,最好情况为logn如何使树的高度保持为logn?14大纲15平衡二叉搜索树1962年由俄罗斯数学家G.M.Adelson-Valskii和E.M.Landis提出,所以简称为AVL树。定义:空树或者是具有以下性质的二叉搜索树左右子树的高度差的绝对值不超过 1且左

6、右子树都是AVL树平衡因子:右子树的高度减左子树的高度。简称:bf16平衡二叉树举例11726391518161410000000-1是AVL树163269718261411不是AVL树-30431100-117平衡化旋转目的:通过旋转使每个结点的 |bf|2四种旋转:左单旋转右单旋转先左后右双旋转先右后左双旋转3060ABC10 123060ABC0018平衡化旋转目的:通过旋转使每个结点的 |bf|2四种旋转:左单旋转右单旋转先左后右双旋转先右后左双旋转3060ABC00-1-23060ABC0-119目的:通过旋转使每个结点的 |bf|2四种旋转:左单旋转右单旋转先左后右双旋转先右后左双

7、旋转平衡化旋转-100903060ABCDhh-11-2-1906030ABCDh0-2-20906030ABCDh0120目的:通过旋转使每个结点的 |bf|2四种旋转:左单旋转右单旋转先左后右双旋转先右后左双旋转平衡化旋转100903060ABCDhh-112-1906030ACBDh0220906030ABCDh-1021平衡化旋转总结3060ABC12-13060ABC-2903060ABCDhh-11-2-1903060ABCDhh-112-1左单旋转右单旋转先左后右先右后左22AVL树的操作和性能操作查找、插入、删除二叉搜索树的方法+平衡旋转时间复杂度O(logn)23大纲24伸展

8、树“八二原则”80%的人只会用到20%的数据正在访问的结点将以很高的概率再次被访问将经常访问的结点放在靠近根的位置,以便再访问。伸展树:对二叉搜索树的改进:每访问完一个结点就把该结点移动到树的根部。25伸展树的旋转方法情况一:被访问结点S的父结点是根结点采用单旋转方式PSABCPSABC26伸展树的旋转方法情况二:同构形状采用一字形旋转方式PSABCGDPSABCGDPSABCGD27伸展树的旋转方法情况三:异构形状采用之字形旋转方式PSABCGDSPABCGDPSABCGD28综合例子803010905020407060803010905020407060803010905020407060803010905020407060一字旋转之字旋转单旋转

温馨提示

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

评论

0/150

提交评论