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.
PHP DSA Implementation
basic.php
<?php
function list_string(array $values): string { return "[" . implode(", ", $values) . "]"; }
function heap_insert(array &$heap, int $value): void {
$heap[] = $value;
$child = count($heap) - 1;
while ($child > 0) {
$parent = intdiv($child - 1, 2);
if ($heap[$parent] <= $heap[$child]) break;
[$heap[$parent], $heap[$child]] = [$heap[$child], $heap[$parent]];
$child = $parent;
}
}
function heap_pop(array &$heap): int {
$smallest = $heap[0];
$heap[0] = array_pop($heap);
$parent = 0;
while (true) {
$left = $parent * 2 + 1; $right = $left + 1;
if ($left >= count($heap)) break;
$child = $left;
if ($right < count($heap) && $heap[$right] < $heap[$left]) $child = $right;
if ($heap[$parent] <= $heap[$child]) break;
[$heap[$parent], $heap[$child]] = [$heap[$child], $heap[$parent]];
$parent = $child;
}
return $smallest;
}
$heap = [1, 4, 2, 9, 6, 7];
$popped = heap_pop($heap);
echo $popped . " -> " . list_string($heap) . PHP_EOL;
?>
@end @output 1 -> [2, 4, 7, 9, 6] @end