数据结构——用C语言描述 -蔡明志 第八章 堆.pptVIP

数据结构——用C语言描述 -蔡明志 第八章 堆.ppt

  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文档。上传文档
查看更多
第8章 堆 堆 了解堆与其的插入和删除操作 关于min-heap 关于min-max heap 及其插入和删除操作 关于Deap及其插入和删除操作 什么是堆 堆(Heap)和二叉查找树大致相同。 堆的定义如下: - 堆是一棵二叉树,其树根的键值大于子树的键值,而且必须是完全二叉树。 - 不管左子树和右子树的大小顺序,这是堆与二叉查找树最大的差异。 - 大致可分为:Max-heap、Min-Max heap及Deap 堆具有新增、删除、输出数据3个功能 堆(Heap)的插入 例:在一棵Heap中插入30及50 步骤如下: (1)按照完全二叉树的特性将30插进来,如图8-9所示。 (2)插入50,但是此时已经不是一棵Heap,要进行调换。 (3)进行调换后,将要插入的那一个节点往上调整即可, 如图8-10所示。 堆(Heap)的插入—示意图 堆(Heap)的删除 什么是min-Heap min-max heap 的定义 min-max heap 的定义 min-max heap 的插入 min-max heap 的插入 min-max heap 的删除 Deap Deap 的插入和删除 8.* ? 2006 * 21世纪高等院校规划教材 返回总目录 在线教务辅导网: 教材其余课件及动画素材请查阅在线教务辅导网 QQ:349134187 或者直接输入下面地址: Heap示图 图8-9 插入30后的完全二叉树状态图 图8-10 插入50后的完全二叉树状态图 Heap的删除: - Heap的删除则将完全二叉树的最后一节点取代被删除的节点, 然后判断是否为一棵Heap,若不是,则再依照上述方法进行调 整。 删除30后的调整方法如图8-11所示。 图8-11 删除30后的调整方法 堆除了max-heap外,还可细分为min-heap、min-max- heap、deap等。 min-heap的概念十分简单,其节点键值一律小于小节 点,恰与max-heap相反,如图8-22所示即为min-heap 的一个例子。 图8-22 min-heap示意图 min-max-heap包含了min-heap与max-heap两种堆的特 征,如图8-27所示即为一棵min-max-heap : min-max-heap必须符合下列3项定义: — min-max-heap是以一层min-heap、一层max-heap 交互构成的 — 树中为min-heap的部分,仍需符合min-heap的特 性 — 树中为max-heap的部分,仍需符合max-heap的特 性 虽然max-max-heap的插入与max-heap的原理差不多, 但是插入后,要调整至符合min-max-heap的定义。 例:假设已存在一棵min-max-heap,如图8-28所示。 向其插入5的操作步骤如下: (1)插入5,如图8-29所示; (2)进行调整:插入5后185,不符合定义第一项; (3)再次进行调整:当步骤(2)调整后10,不符合定义第二 项; (4)操作结束,符合min-max-heap的定义。 图8-28 min-max-heap示意图 图8-29 插入5后的示意图 图8-30 交换5和18后的示意图 图8-31 交换5和10后的示意图 插入5 5 与 18 交 换 5与10交换 min-max-heap的删除同min-max-heap的插入一样, 其结果要符合定义。 若删除min-max-heap的最后一个节点,则直接删除 即可;否则,先将删除节点键值与树中的最后一个 节点对调,再做调整操作,即以最后一个节点取代 被删除节点。 Deap同样也具备max-heap与min-heap的特征。 图8-41 Deep示意图 Deap其定义如下: (1)Deap的树根不储存任何数据,为一空节点。 (2)树根的左子树,为一棵min-heap;右子树则为max-heap。 (3)min-heap与max-heap存在对应关系。 Deap

您可能关注的文档

文档评论(0)

118压缩包课件库 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档