bg_image
header

Max Heap

A Max-Heap is a type of binary heap where the key or value of each parent node is greater than or equal to those of its child nodes. This means that the largest value in the Max-Heap is always at the root (the topmost node). Max-Heaps have the following properties:

  1. Complete Binary Tree: A Max-Heap is a completely filled binary tree, meaning all levels are fully filled except possibly the last level, which is filled from left to right.

  2. Heap Property: For every node i with child nodes 2i+1 (left) and 2i+2 (right), the value of the parent node i is greater than or equal to the values of the child nodes. Mathematically: A[i]≥A[2i+1] and A[i]≥A[2i+2], if these child nodes exist.

Uses of Max-Heaps

Max-Heaps are useful in various applications where the largest element needs to be accessed frequently. Some common uses include:

  1. Priority Queue: Max-Heaps are often used to implement priority queues where the element with the highest priority (the largest value) is always at the top.

  2. Heapsort: The Heapsort algorithm can use Max-Heaps to sort elements in ascending order by repeatedly extracting the largest element.

  3. Graph Algorithms: While Max-Heaps are not as commonly used in graph algorithms as Min-Heaps, they can still be useful in certain scenarios, such as when managing maximum spanning trees or scheduling problems where the largest element is of interest.

Basic Operations on a Max-Heap

The basic operations that can be performed on a Max-Heap include:

  1. Insert: A new element is added at the last position and then moved up (Bubble-Up) to restore the heap property.

  2. Extract-Max: The root element (the largest element) is removed and replaced by the last element. This element is then moved down (Bubble-Down) to restore the heap property.

  3. Get-Max: The root element is returned without removing it. This has a time complexity of O(1).

  4. Heapify: This operation restores the heap property when it is violated. There are two variants: Heapify-Up and Heapify-Down.

Example

Suppose we have the following elements: [3, 1, 6, 5, 2, 4]. A Max-Heap representing these elements might look like this:

       6
     /   \
    5     4
   / \   /
  1   3 2

Here, 6 is the root of the heap and the largest element. Every parent node has a value greater than or equal to the values of its child nodes.

Summary

A Max-Heap is an efficient data structure for managing datasets where the largest element needs to be repeatedly accessed and removed. It ensures that the largest element is always easily accessible at the root, making operations like extracting the maximum value efficient.

 

 


Min Heap

A Min-Heap is a specific type of binary heap (priority queue) where the key or value of the parent node is always less than or equal to that of the child nodes. This means that the smallest value in the Min-Heap is always at the root (the topmost node). Min-Heaps have the following properties:

  1. Complete Binary Tree: A Min-Heap is a completely filled binary tree, meaning all levels are fully filled except possibly for the last level, which is filled from left to right.

  2. Heap Property: For every node ii with child nodes 2i+12i+1 (left) and 2i+22i+2 (right), the value of the parent node ii is less than or equal to the values of the child nodes. Mathematically: A[i]≤A[2i+1]A[i] \leq A[2i+1] and A[i]≤A[2i+2]A[i] \leq A[2i+2], if these child nodes exist.

Uses of Min-Heaps

Min-Heaps are often used in algorithms that repeatedly extract the smallest element from a set. Here are some common applications:

  1. Priority Queue: Min-Heaps are used to implement priority queues, where the element with the highest priority (in this case, the smallest value) is always at the top.

  2. Heapsort: The Heapsort algorithm can be implemented with Min-Heaps or Max-Heaps. With a Min-Heap, the smallest element is repeatedly extracted to produce a sorted list.

  3. Graph Algorithms: Min-Heaps are used in graph algorithms like Dijkstra's algorithm for finding the shortest paths and Prim's algorithm for finding minimum spanning trees.

Basic Operations on a Min-Heap

The basic operations that can be performed on a Min-Heap include:

  1. Insert: A new element is added at the last position and then moved up (Bubble-Up) to restore the heap property.

  2. Extract-Min: The root element (the smallest element) is removed and replaced by the last element. This element is then moved down (Bubble-Down) to restore the heap property.

  3. Get-Min: The root element is returned without removing it. This has a time complexity of O(1)O(1).

  4. Heapify: This operation restores the heap property when it is violated. There are two variants: Heapify-Up and Heapify-Down.

Example

Suppose we have the following elements: [3, 1, 6, 5, 2, 4]. A Min-Heap representing these elements might look like this:

       1
     /   \
    2     4
   / \   /
  5   3 6

Here, 1 is the root of the heap and the smallest element. Every parent node has a value less than or equal to the values of its child nodes.

In summary, a Min-Heap is an efficient data structure for managing datasets where the smallest element needs to be repeatedly accessed and removed.

 

 


Heap

A heap is a special tree-based data structure that satisfies specific properties, making it highly efficient for certain algorithms, such as priority queues. There are two main types of heaps: Min-Heaps and Max-Heaps.

Key Features of a Heap

  1. Binary Tree Structure: Heaps are binary trees where each parent node has at most two child nodes.
  2. Heap Property:
    • Min-Heap: The value of each parent node is less than or equal to the values of its child nodes. The smallest element is at the root.
    • Max-Heap: The value of each parent node is greater than or equal to the values of its child nodes. The largest element is at the root.

Use Cases

  1. Priority Queues: Heaps are ideal for implementing priority queues, where the element with the highest priority (smallest or largest value) can be efficiently removed.
  2. Heapsort: An efficient comparison-based sorting algorithm that uses heap properties.
  3. Dijkstra’s Algorithm: Uses heaps to efficiently calculate the shortest paths in a graph.

Heap Operations

  1. Insert: A new element is added to the end of the heap and then "percolated up" until the heap property is restored.
  2. Remove Root: The root element is removed, and the last element in the heap is moved to the root and "percolated down" until the heap property is restored.
  3. Peek: Returns the value at the root without removing it.

Example in PHP

Here is a simple example of implementing a Min-Heap in PHP:

class MinHeap {
    private $heap;

    public function __construct() {
        $this->heap = [];
    }

    public function insert($value) {
        $this->heap[] = $value;
        $this->percolateUp(count($this->heap) - 1);
    }

    public function extractMin() {
        if (count($this->heap) === 0) {
            return null; // Heap is empty
        }

        $min = $this->heap[0];
        $this->heap[0] = array_pop($this->heap);
        $this->percolateDown(0);

        return $min;
    }

    private function percolateUp($index) {
        while ($index > 0) {
            $parentIndex = intdiv($index - 1, 2);

            if ($this->heap[$index] >= $this->heap[$parentIndex]) {
                break;
            }

            $this->swap($index, $parentIndex);
            $index = $parentIndex;
        }
    }

    private function percolateDown($index) {
        $lastIndex = count($this->heap) - 1;

        while (true) {
            $leftChild = 2 * $index + 1;
            $rightChild = 2 * $index + 2;
            $smallest = $index;

            if ($leftChild <= $lastIndex && $this->heap[$leftChild] < $this->heap[$smallest]) {
                $smallest = $leftChild;
            }

            if ($rightChild <= $lastIndex && $this->heap[$rightChild] < $this->heap[$smallest]) {
                $smallest = $rightChild;
            }

            if ($smallest === $index) {
                break;
            }

            $this->swap($index, $smallest);
            $index = $smallest;
        }
    }

    private function swap($index1, $index2) {
        $temp = $this->heap[$index1];
        $this->heap[$index1] = $this->heap[$index2];
        $this->heap[$index2] = $temp;
    }
}

// Example usage
$heap = new MinHeap();
$heap->insert(5);
$heap->insert(3);
$heap->insert(8);
$heap->insert(1);

echo $heap->extractMin(); // Output: 1
echo $heap->extractMin(); // Output: 3
echo $heap->extractMin(); // Output: 5
echo $heap->extractMin(); // Output: 8

In this example, a Min-Heap is implemented where the smallest elements are extracted first. The insert and extractMin methods ensure that the heap properties are maintained after each operation.