二叉堆、并查集和树状数组【信息技术】.pdfVIP

二叉堆、并查集和树状数组【信息技术】.pdf

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
二叉堆、并查集和树状数组 刘汝佳 优先队列 • 优先队列(priority queue): 可以把元素加入 到优先队列中, 也可以从队列中取出优先级 最高的元素, 即以下ADT – Insert(T, x): 把x加入优先队列中 – DeleteMin(T, x): 获取优先级最高的元素x, 并 把它从优先队列中删除 堆的操作 • 用二叉堆(binary heap)很容易实现优先队列 • 除了实现优先队列, 堆还有其他用途, 因此 操作比优先队列多 – Getmin(T, x): 获得最小值 – Delete(T, x): 删除任意已知结点 – DecreaseKey(T, x, p): 把x 的优先级降为p – Build(T, x): 把数组x建立成最小堆 堆的定义 • 堆是一个完全二叉树 – 所有叶子在同一层或者两个连续层 – 最后一层的结点占据尽量左的位置 • 堆性质 – 为空, 或者最小元素在根上 – 两棵子树也是堆 存储方式 • 最小堆的元素保存在heap[1..hs] 内 – 根在heap[1] – K 的左儿子是2k, K的右儿子是2k+1, – K 的父亲是[k/2] 1 1 2 3 2 3 4 5 6 7 4 5 6 7 8 9 10 11 12 13 14 8 9 10 11 12 13 14 删除最小值元素 • 三步法 – 直接删除根 – 用最后一个元素代替根上元素 – 向下调整 1 13 1 13 2 3 2 3 2 3 2 3 4 5 6 7 4 5 6 7 4 5 6 7 4 5 6 7 8 9 10 11 12 13 8 9 10 11 12 8 9 10 11 12 13 8 9 10 11 12 • 首先选取当前结点p的较大儿子. 如

文档评论(0)

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档