Heap sort
Heapsort is a comparison-based sorting algorithm to create a sorted array (or list), and is part of the selection sort family.
Although somewhat slower in practice on most machines than a well-implemented quicksort, it has the advantage of a more favorable worst-case O(n log n) runtime.
Algorithm
MAX-HEAPIFY(A,i) 1. l = LEFT(i) 2. r = RIGHT(i) 3. if l <= A.heap-size and A[l] > A[i] 4. largest = l 5. else largest = i 6. if r <= A.heap-size and A[r] > A[largest] 7. largest = r 8. if largest != i 9. exchange A[i] with A[largest] 10. MAX-HEAPIFY(A,largest) BUILD-MAX-HEAP(A) 1. A.heap-size = A.length 2. for i = [A.length/2] downto 1 3. MAX-HEAPIFY(A, i) HEAPSORT(A) 1. BUILD-MAX-HEAP(A) 2. for i = A.length downto 2 3. exchange A[1] with A[i] 4. A.heap-size = A.heap-size - 1 5. MAX-HEAPIFY(A, 1)
Heap sort Implementation
#include<stdio.h>
#include<conio.h>
void manage(int *, int);
void heapsort(int *, int, int);
void main()
{
int arr[20];
int i,j,size,tmp,k;
clrscr();
printf("\n\t\t\t------- Heap sorting method -------\n\n");
printf("Enter the number of elements to sort : ");
scanf("%d",&size);
printf("Enter The Element In Array\n");
for(i=1; i<=size; i++)
{
scanf("%d",&arr[i]);
manage(arr,i);
}
j=size;
for(i=1; i<=j; i++)
{
tmp=arr[1];
arr[1]=arr[size];
arr[size]=tmp;
size--;
heapsort(arr,1,size);
}
printf("\n\t\t\t------- Heap sorted elements -------\n\n");
size=j;
printf("Sorted Elements:\t");
for(i=1; i<=size; i++)
printf("%d\t ",arr[i]);
getch();
}
void manage(int *arr, int i)
{
int tmp;
tmp=arr[i];
while((i>1) && (arr[i/2]< tmp))
{
arr[i]=arr[i/2];
i=i/2;
}
arr[i]=tmp;
}
void heapsort(int *arr, int i, int size)
{
int tmp,j;
tmp=arr[i];
j=i*2;
while(j<=size)
{
if((j < size) && (arr[j] < arr[j+1]))
j++;
if(arr[j] < arr[j/2])
break;
arr[j/2]=arr[j];
j=j*2;
}
arr[j/2]=tmp;
}
OUTPUT

