左偏堆的特点及其应用PPT课件.ppt_第1页
左偏堆的特点及其应用PPT课件.ppt_第2页
左偏堆的特点及其应用PPT课件.ppt_第3页
左偏堆的特点及其应用PPT课件.ppt_第4页
左偏堆的特点及其应用PPT课件.ppt_第5页
已阅读5页,还剩17页未读 继续免费阅读

下载本文档

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

文档简介

.,1,左偏树的特点及其应用,广东省中山市第一中学黄源河,.,2,左偏树的定义,左偏树(LeftistTree)是一种可并堆(MergeableHeap),它除了支持优先队列的三个基本操作(插入,删除,取最小节点),还支持一个很特殊的操作合并操作。左偏树是一棵堆有序(HeapOrdered)二叉树。左偏树满足左偏性质(LeftistProperty)。,.,3,左偏树的定义左偏性质,定义一棵左偏树中的外节点(ExternalNode)为左子树或右子树为空的节点。定义节点i的距离(dist(i)为节点i到它的后代中,最近的外节点所经过的边数。任意节点的左子节点的距离不小于右子节点的距离(左偏性质)。由左偏性质可知,一个节点的距离等于以该节点为根的子树最右路径的长度。,.,4,左偏树的性质,定理:若一棵左偏树有N个节点,则该左偏树的距离不超过log(N+1)-1。,最右路径:ACG最右路径节点数=3距离=2,8个节点的左偏树的最大距离:log(8+1)-1=2,.,5,左偏树的操作,左偏树支持下面这些操作:MakeNull初始化一棵空的左偏树Merge合并两棵左偏树Insert插入一个新节点Min取得最小节点DeleteMin删除最小节点Delete删除任意已知节点Decrease减小一个节点的键值,.,6,左偏树的操作合并,合并操作是递归进行的,合并T1和T2两棵左偏树,先将T1的右子树与T2合并,.,7,左偏树的操作合并,合并操作是递归进行的,a,L1,R,先将T1的右子树与T2合并,.,8,左偏树的操作合并,合并操作是递归进行的,交换左右子树并更新根节点距离,合并后的右子树距离可能大于左子树距离,.,9,左偏树的操作合并,合并操作的代码如下:FunctionMerge(A,B)IfA=NULLThenreturnBIfB=NULLThenreturnAIfkey(B)dist(left(A)Thenswap(left(A),right(A)Ifright(A)=NULLThendist(A)0Elsedist(A)dist(right(A)+1returnAEndFunction,.,10,左偏树的操作合并,下面是一个合并的例子:,.,11,左偏树的操作合并,下面是一个合并的例子:,.,12,左偏树的操作合并,下面是一个合并的例子:,.,13,左偏树的操作合并,下面是一个合并的例子:,18,NULL,.,14,左偏树的操作合并,下面是一个合并的例子:,37,7,0,1,?,.,15,左偏树的操作合并,下面是一个合并的例子:,1,1,2,26,17,37,18,8,7,.,16,左偏树的操作合并,下面是一个合并的例子:,0,2,?,.,17,左偏树的操作合并,下面是一个合并的例子:,3,10,2,0,1,.,18,左偏树的操作合并,合并操作都是一直沿着两棵左偏树的最右路径进行的。一棵N个节点的左偏树,最右路径上最多有log(N+1)个节点。因此,合并操作的时间复杂度为:O(logN1+logN2)=O(logN),.,19,左偏树的操作插入,插入一个新节点把待插入节点作为一棵单节点左偏树合并两棵左偏树时间复杂度:O(logN),.,20,左偏树的操作删除,删除最小节点删除根节点合并左右子树时间复杂度:O

温馨提示

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

评论

0/150

提交评论