Deletion in MIN-MAX Heaps Delete min element Delete max element
Delete min element in min-max heap Step1: 移走 root 資料 Step2: 將 heap 的 last-node X 插入 ste1 後的 heap 中 Case1 : Root 沒有任何 child : X 插入 root 位置 Case2 : Root 只有 children 沒有 grandchild 令 children 中最小值為 k 若 k < X 則將 X 與 k 互換位置 否則將 X 插入 root 位置 Case3 : Root 有 grandchildren 令 grandchildren 中最小值為 k 且 k 之 parent 為 p 若 k < X 則 K 移到 X 的位子 若 X > p 則 X 與 p 的值互換 重複 step2 否則將 X 插入 root 位置
EX: Delete min element Delete min element min max min max
EX: Delete min element Step1: remove root data 7 min max min max
EX: Delete min element Step2: insert last node (12) into root min max min max
9 EX: Delete min element Step2 Case3 : Node 12 有 grandchildren. Grandchildren 之最小者 9 <12 ->Exchange 9, 12 檢查 12 < 70 ok ! 回到 step2 minimal
EX: Delete min element Step2 Case 2 : Node 12 只有 children. Children 中最小者 20 > 12 將 12 insert 到該位子
EX: Delete min element Done min max min max
Delete max element in min-max heap Step1: 若只有一個 node 則移走 root, 結束 否則移走 root 之 children 之最大者, 進行 step2 Step2: 將 heap 的 last-node X 插入 ste1 後的 heap 空位中 Case1 : 此位置沒有任何 child : X 插入此位置 Case2 : 此位子為 root 之 sub-tree 只有 children 沒有 grandchild 令 children 中最大值為 k 若 k > X 則將 X 與 k 互換位置 否則將 X 插入 root 位置 Case3 : Root 有 grandchildren 令 grandchildren 中最大值為 k 且 k 之 parent 為 p 若 k > X 則 K 移到 X 的位子 若 X < p 則 X 與 p 的值互換 重複 step2 否則將 X 插入 root 位置
EX: Delete max element Delete max element min max min max
EX: Delete max element Step1: remove 70 min max min max 70
EX: Delete max element Step2: insert last node (12) into root min max min max
9 EX: Delete max element Step2 Case3 : Node 12 有 grandchildren. Grandchildren 之最大者 50 < 12 ->Exchange 50, 12
9 EX: Delete max element Step2 Case3 : 檢查 12 與其 parent 30 發現 12<30 12 與 30 互換 重複 Step2 檢查 30 之位子 min max min max
9 EX: Delete max element Step2 Case1 : Node 30 沒有 children ok!
EX: Delete min element Done min max min max