Download presentation
Presentation is loading. Please wait.
Published byGiustino Lupi Modified over 5 years ago
1
Algorithms CSCI 235, Spring 2019 Lecture 14 Heap Sort Read: Ch. 6
2
A Heap is a Binary Tree Height of tree
= longest path from root to leaf = Q(lgn) A heap is a binary tree satisfying the heap condition: At every node in a heap, the node value is >= all the values in its subtrees. A heap with heap_size elements can be represented as an array segment: A[1..heap_size]
3
Ordering of Nodes Each node is filled in order from left to right.
1 16 Each node is filled in order from left to right. All rows are filled except, possibly, the last row. 3 2 14 10 5 4 9 6 3 7 8 7 8 9 10 2 4 1 Address of left child of node i => 2i Address of right child of node i => 2i+1 Address of parent of node i => Example: Left(4) = 8 Right(4) = 9 Parent(4) = 2
4
Heap properties At every node in the heap, that node's value is greater than or equal to all the values in the subtrees of that node. Heaps can be represented as an array. The elements in the array occur in the order of their heap addresses. A= Note that the array is not sorted. Can guarantee that A[1] is the maximum value in the array.
5
Building a Heap To perform a heap sort, we must first build a heap out of our unsorted array. To build a heap, we will use the function heapify, which creates a heap from a node i and two subtrees that are already heaps.
6
Heapify 1 16 Example: i = 2 Want to move the value, 3, to a position consistent with the heap property. 3 i=2 3 14 5 4 9 6 11 7 15 6 8 9 10 7 8 2 In English: Compare the value at node i with the values at each child node. Swap the value at node i with the largest of those values. Repeat with the subtree that ith value was swapped into. Note: If the value at i is in the correct place, it will be swapped with itself and the algorithm is done.
7
Pseudocode for Heapify
Max-Heapify (A, i) lft = Left(i) rt = Right(i) if lft ≤ A.heap-size and A[lft] > A[i] largest = lft else largest = i if rt ≤ A.heap-size and A[rt] > A[largest] largest = rt if largest ≠ i Swap(A, i, largest ); Max-Heapify (A, largest);
8
Final Tree from example
1 16 3 i=2 15 14 5 4 8 6 9 6 11 7 8 9 10 7 3 2 Can show that heapify runs in O(lgn) time. (Why?)
9
Building a Heap Each leaf of a binary tree is already a heap of size 1. Build-Heap will start with the highest addressed, non-leaf node and heapify it. It then repeats with each node addressed 1 less than the previous node. In a binary tree, the leaf nodes have addresses: We want to heapify starting with node: Build-Max-Heap(A) A.heap-size = A.length for i = A.length / 2 downto 1 Max-Heapify(A, i)
10
Example A= 4 7 16 3 27 9 10 34 1 25 We will work this out in class. 4
8 9 10 34 1 25 We will work this out in class.
11
Heap Sort In English: Build a Heap out of the elements of the array
We know that the maximum value is at A[1], so we swap it with the last element of the heap. Reduce the size of the heap by 1. Heapify the new, smaller heap. Repeat this process until all the nodes have been sorted.
12
Pseudocode for Heapsort
Heapsort(A) Build-Max-Heap(A) for i = A.length downto 2 Swap(A, 1, i) A.heap-size = A.heap-size - 1 Max-Heapify (A, 1) What is the running time of Heapsort? Must find running times of Build-Heap and Heapify first.
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.