w3resource

C Exercises: Heap sort algorithm (MAX heap)


5. Max Heap Sort Variants

Write a C program to sort numbers using the MAX heap algorithm.

Note: A sorting algorithm that works by first organizing the data to be sorted into a special type of binary tree called a heap.

Sample Solution:

Sample C Code:

#include <stdio.h>
int main() {
    int arr[10], no, i, j, c, heap_root, temp;
    // Input the number of elements
    printf("Input number of elements: ");
    scanf("%d", &no);
    // Input array values one by one
    printf("\nInput array values one by one: ");
    for (i = 0; i < no; i++)
        scanf("%d", &arr[i]);
    // Build a max heap using the heapify-up procedure
    for (i = 1; i < no; i++) {
        c = i;
        do {
            heap_root = (c - 1) / 2;
            // Create a max heap array
            if (arr[heap_root] < arr[c]) {
                temp = arr[heap_root];
                arr[heap_root] = arr[c];
                arr[c] = temp;
            }
            c = heap_root;
        } while (c != 0);
    }
    // Display the heap array
    printf("Heap array: ");
    for (i = 0; i < no; i++)
        printf("%d\t", arr[i]);
    // Extract elements from the heap to build the sorted array
    for (j = no - 1; j >= 0; j--) {
        temp = arr[0];
        arr[0] = arr[j];
        arr[j] = temp;
        heap_root = 0;
        // Heapify-down procedure to maintain the max heap property
        do {
            c = 2 * heap_root + 1;
            // Check if the right child is greater than the left child
            if ((arr[c] < arr[c + 1]) && c < j - 1)
                c++;
            // Swap if the root is smaller than the child
            if (arr[heap_root] < arr[c] && c < j) {
                temp = arr[heap_root];
                arr[heap_root] = arr[c];
                arr[c] = temp;
            }
            heap_root = c;
        } while (c < j);
    }
    // Display the sorted array
    printf("\nSorted array: ");
    for (i = 0; i < no; i++)
        printf("\t%d", arr[i]);
    printf("\n");
    return 0;
}

Sample Input:

3
12
15
56

Sample Output:

Input number of elements: 
Input array values one by one : Heap  array : 56	 12	 15	 
Sorted  array : 	12	15	56

Flowchart:

Flowchart: C Programming - Heap algorithm(MAX heap)

For more Practice: Solve these Related Problems:

  • Write a C program to build a max heap from an unsorted array and extract the maximum repeatedly to sort the array.
  • Write a C program to implement heap sort using a max heap and count the number of heapify operations performed.
  • Write a C program to modify heap sort to sort an array in descending order using a max heap.
  • Write a C program to build a max heap, then replace the root with a new value and restore the heap property.

C Programming Code Editor:



Previous: Write a C program to sort a list of elements using the merge sort algorithm.
Next: Write a C program to sort a list of elements using the quick sort algorithm.

What is the difficulty level of this exercise?

Test your Programming skills with w3resource's quiz.



Follow us on Facebook and Twitter for latest update.