资料结构-使用C语言873二元搜寻树的删除.PPT

  1. 1、本文档共12页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
资料结构-使用C语言873二元搜寻树的删除

Chapter 7 二元搜尋樹 7.1 何謂二元搜尋樹 7.2 二元搜尋樹的加入 7.3 二元搜尋樹的刪除 7.1 何謂二元搜尋樹 二元搜尋樹可以是空集點,假使不是空集合,則樹中的每一節點(node)均含有一鍵值(key value),而且具有下列特性: 在左子樹的所有鍵值均小於樹根的鍵值。 在右子樹的所有鍵值均大於樹根的鍵值。 左子樹和右子樹亦是二元搜尋樹。 每個鍵值都不一樣。 7.1 何謂二元搜尋樹 其中(a)為一棵二元搜尋樹,而(b)圖形就不是一棵二元搜尋樹,因為鍵值30不應該在鍵值40的右邊。 7.2 二元搜尋樹的加入 二元搜尋樹的加入和刪除很簡單,因二元搜尋樹的特性是左子樹鍵值均小於樹根的鍵值,而右子樹的鍵值任均大於樹根的鍵值。 因此加入某一鍵值只要逐一比較,依據鍵值的大小往右或往左,便可找到此鍵值欲加入的適當位置。 7.2 二元搜尋樹的加入 假設有棵二元搜尋樹如下: 7.2 二元搜尋樹的加入 今欲加入48 7.2 二元搜尋樹的加入 繼續加入90則為 7.3 二元搜尋樹的刪除 刪除某一節點時,若刪除的是樹葉節點,則直接刪除之,假若刪除不是樹葉節點,則在左子樹找一最大的節點或在右子樹找一最小的節點, 取代將被刪除的節 點,如 7.3 二元搜尋樹的刪除 刪除50,則可用下列二種方法之一: 7.3 二元搜尋樹的刪除 若取代的節點有右子樹或左子樹時,則必須加以調整其子節點,如 7.3 二元搜尋樹的刪除 今欲刪除50,若以右子樹中最小節點取代刪除節點的話,則60將取代50,但60節點有右子樹(一定不會有左子樹,為什麼?),此時必須將其右子樹重新放在60節點之父節點(65)的左邊鏈結。 7.3 二元搜尋樹的刪除 反之,若以左子樹的最大節點來取代刪除節點的話,則45將取代50,但45此時有左子樹(一定不會有右子樹,為什麼?),此時必須將其左子樹重新放在45節點之父節點(40)的右邊鏈結上。

文档评论(0)

xiaozu + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档