08-heaps
Min-Heap Pop (Sift Down)
Remove the minimum value, move the last item to the root, and sift downward.
Algorithm
@steps
- Store the heap in an array.
- Compare parent and child indexes instead of building explicit tree nodes.
- Swap only when the heap order is violated.
- Print the deterministic final heap state for replay comparison. @end @complexity
- Time: O(log n)
- Space: O(1) extra @end
sift down
After removing the root, the last value moves to the root and swaps with the smaller child until order is restored.
Ruby DSA Implementation
basic.rb
def list_string(values) = "[#{values.join(', ')}]"
def heap_insert(heap, value)
heap << value
child = heap.length - 1
while child > 0
parent = (child - 1) / 2
break if heap[parent] <= heap[child]
heap[parent], heap[child] = heap[child], heap[parent]
child = parent
end
end
def heap_pop(heap)
smallest = heap[0]
heap[0] = heap.pop
parent = 0
loop do
left = parent * 2 + 1
right = left + 1
break if left >= heap.length
child = right < heap.length && heap[right] < heap[left] ? right : left
break if heap[parent] <= heap[child]
heap[parent], heap[child] = heap[child], heap[parent]
parent = child
end
smallest
end
heap = [1, 4, 2, 9, 6, 7]
popped = heap_pop(heap)
puts "#{popped} -> #{list_string(heap)}"
@end @output 1 -> [2, 4, 7, 9, 6] @end