- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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的较大儿子. 如
您可能关注的文档
最近下载
- 高级日语(三)第08課 携帯上司 8課内容理解1.ppt VIP
- 全麻术后导尿管相关膀胱刺激征的管理.pptx VIP
- 精选洗车场租赁协议2024年通用.docx VIP
- 国家中小学智慧教育平台的应用培训(OCR).pdf VIP
- 鲁宾逊漂流记:英汉对照版-英DanielDefoe.pdf VIP
- 伤口造口护理.pptx VIP
- UFDEV_PHASE_1_5_5_项目客户化开发推进计划.xls VIP
- 2024-2025学年高一数学必修一《第一章 集合与常用逻辑用语》测试卷附答案解析.pdf VIP
- 某电厂引风机拆除安装实施方案.doc VIP
- 口语交际--有趣的动物及口语交际《有趣的动物》教案.doc VIP
文档评论(0)