- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
作业讲解;作业8;作业8;优先队列(priority_Queue);优先队列(priority_Queue);优先队列-线性表;优先队列-二叉树;(13,38,27,50,76,65,49,97);堆是满足下列性质的数列{r1, r2, …,rn}:;小顶堆:??? 根结点(亦称为堆顶)的关键字是堆里所有结点关键字中最小者的堆称为小顶堆。
大顶堆:??? 根结点(亦称为堆顶)的关键字是堆里所有结点关键字中最大者,称为大顶堆。
注意:??? ①堆中任一子树亦是堆。??? ②以上讨论的堆实际上是二叉堆(Binary Heap),类似地可定义k叉堆。;;二叉堆-插入过程(大顶堆);课堂练习;;方法:
1.输出堆顶元素之后,以堆中最后一个元素替代之;
2.然后将根结点值与左、右子树的根结点值进行比较,并与其中大者进行交换;
3.重复上述操作,直至叶子结点,将得到新的堆,称这个从堆顶至叶子的调整过程为“筛选”;课堂练习;方法:
1、将队列想像成一棵完全二叉树
2、从下往上,按层调整,将每个子树调整成堆
注意:最下面的子树的根节点是第?n/2?号元素;;;1、判断下列序列是否是堆,如果不是,请调整为堆
a.100,85,98,77,80,60,82,40,20,10,66
b.100,98,85,82,80,77,66,60,40,20,10
c.100,85,40,77,80,60,66,98,82,10,20
d.10,20,40,60,66,77,80,82,85,98,100;优先队列抽象类;MaxHeap类;MaxHeap类-构造函数;MaxHeap类-插入函数;MaxHeap类-删除函数;初始堆的建立;MaxHeap类-输出函数-测试用;堆排序;堆排序;;;;;;堆排序;初始堆的建立;1. 对深度为 k 的堆,“筛选(调整)”所需进行的关键字比较的次数至多为2(k-1);;因此,堆排序的时间复杂度为O(nlogn)。
堆排序的平均性能较接近于最坏性能。
辅助空间为O(1) ;作业10
原创力文档


文档评论(0)