算法设计与分析-6堆排序

算法设计与分析-6堆排序

ID:19914511

大小:579.00 KB

页数:27页

时间:2018-10-07

算法设计与分析-6堆排序_第1页
算法设计与分析-6堆排序_第2页
算法设计与分析-6堆排序_第3页
算法设计与分析-6堆排序_第4页
算法设计与分析-6堆排序_第5页
资源描述:

《算法设计与分析-6堆排序》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、算法设计与分析谭守标安徽大学电子学院2007.9第五章堆排序堆的基本概念和性质堆的基本操作(过程及分析)堆排序算法(过程及分析)堆排序应用—优先级队列(过程及分析)程序展示和讲解一、堆的基本概念和性质1、定义:堆可看作为一完全二叉树,大根堆的任一非终端节点(叶子节点)的数据不小于其子节点的数据。2、两个特点:①根节点上为该堆的最大元素。②较大的数据位于较低的层次。堆的属性1、length[A]:数组中的元素个数2、heapsize[A]:存放在A中的堆的元素个数显然heapsize[A]≤length[A]3、给定一个节点的下标i,其父节点为┖i/2┚,其左儿子[

2、LEFT(i)]为2i、右儿子[RIGHT(i)]为2i+1.五个基本过程1、HEAPIFY过程:维持堆性质,运行时间O(lgn).2、BUILD--HEAP过程:从无序的输入数组中构造出一个堆来,运行时间O(n).3、HEAPSORT过程:对一个数组进行排序,运行时间O(nlgn).4、EXTRACT--MAX和INSERT过程:是堆结构可以作为一个优先级队列来用,运行时间O(lgn).堆实例二、堆的基本操作HEAPIFY过程1、过程说明:对于第i个数,假定以它左儿子[LEFT(i)]和右儿子[RIGHT(i)]为根的两棵子树都已为堆,调用HEAPIFY使得以i

3、为根的子树成为一个的堆。2、过程图例3、算法如下1、l←LEFT(i)2、r←RIGHT(i)3、ifl≤heapsize(A)andA[l]>A[i]4、thenlargest←l5、elselargest←i6、ifr≤heapsize(A)andA[r]>A[largest]7、thenlargest←r8、iflargest≠i9、thenexchangeA[i]←→A[largest]10、HEAPIFY(A,largest)4、运行时间①T(n)=T(2/3n)+Θ(1)可得T(n)=O(lgn)②因为堆的高度最大为lgn所以可知T(n)=O(lgn)

4、BUILD-HEAP过程1、图例2、BUILD-HEAP(A)算法1)heapsize[A]←length[A]2)fori←┖length[A]/2┚downto13)doHEAPIFY(A,i)3、运行时间粗估:每调一次HEAPIFY(A,i)的时间为O(lgn),总共有O(n)次调用,故运行时间最多为O(nlgn).此时间是不紧确的。紧确估计:含n个元素的堆中至多有个节点的高度为h三、堆排序算法1、图例:2、算法1)BUILDHEAP(A)2)fori←length[A]downto23)doexchangeA[1]←→A[i]4)heapsize(A)←→

5、heapsize(A)-15)HEAPIFY(A,1)3、运行时间堆排序的时间建堆的时间为O(n)+(n-1)次的HEAPIFY调用时间O(lgn),所以总的代价为O(nlgn)四、优先级队列一、常见操作1、INSERT(S,x):把元素x插入集合S.可记为S←S∪{x}.2、MAXIMUM(S):返回S中具有最大关键字的元素。3、EXTRACT—MAX(S):去掉并返回S中具有最大关键字的元素。HEAP-EXTRACT-MAX过程HEAP—EXTRACT—MAX(A)ifheap—size[A]<1thenerror“heapunderflow”max←A[1]

6、A[1]←A[heap—size[A]]heap—size[A]←heap—size[A]-1HEAPIFY(A,1)returnmaxHEAP-EXTRACT-MAX过程运行时间从算法中可以看出该过程的运行时间为O(lgn)。INSERT(S,x)过程1、图例2、HEAP—INSERT(A,key)算法1、heap—size[A]←heap—size[A]+12、i←heap—size[A]3、whilei>1andA[PARENT(i)]

7、五章堆排序概念:二叉树、完全二叉树、根、叶节点、内节点、兄弟节点、度疑问:堆中兄弟节点大小无序,为什么?逆序输出时如何操作?插入时如何操作?(插入操作也可建堆)TheEndThankyou!

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。