C Exercises: Quick sort
Write a C program to implement quick sort using callback function.
Note: Quick sort is a comparison sort, meaning that it can sort items of any type for which a "less-than" relation is defined.
Read n values into array and Sort using Quick Sort.
Sample Solution:
C Code:
#include <stdio.h>
#include <stdlib.h>
typedef int( * compare_func_t)(const void * ,
const void * );
void swap(void * a, void * b, size_t size) {
char * p = (char * ) a;
char * q = (char * ) b;
char tmp;
for (size_t i = 0; i < size; i++) {
tmp = p[i];
p[i] = q[i];
q[i] = tmp;
}
}
void * partition(void * base, size_t nmemb, size_t size, compare_func_t compare) {
char * pivot = (char * ) base;
char * left = (char * ) base + size;
char * right = (char * ) base + (nmemb - 1) * size;
while (1) {
while (left <= right && compare(left, pivot) < 0) {
left += size;
}
while (left <= right && compare(right, pivot) > 0) {
right -= size;
}
if (left > right) {
break;
}
swap(left, right, size);
left += size;
right -= size;
}
swap(pivot, right, size);
return (void * ) right;
}
void quicksort(void * base, size_t nmemb, size_t size, compare_func_t compare) {
if (nmemb <= 1) {
return;
}
char * cbase = (char * ) base; // Cast the void* pointer to a char* pointer
void * pivot = partition(cbase, nmemb, size, compare);
quicksort(cbase, ((char * ) pivot - cbase) / size, size, compare); // Cast pointers to char* before doing pointer arithmetic
quicksort((char * ) pivot + size, nmemb - ((char * ) pivot - cbase) / size - 1, size, compare); // Cast pointers to char* before doing pointer arithmetic
}
int intcmp(const void * a,
const void * b) {
return ( * (int * ) a - * (int * ) b);
}
int main() {
int arr[] = {
5,
2,
8,
7,
1,
3,
6,
4
};
size_t nmemb = sizeof(arr) / sizeof(arr[0]);
printf("Before sorting: ");
for (size_t i = 0; i < nmemb; i++) {
printf("%d ", arr[i]);
}
printf("\n");
quicksort(arr, nmemb, sizeof(int), intcmp);
printf("After sorting: ");
for (size_t i = 0; i < nmemb; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
Sample Output:
Before sorting: 5 2 8 7 1 3 6 4 After sorting: 1 2 3 4 5 6 7 8
Note: The results may vary due to srand() function is used to seed the random number.
Explanation:
In the above example, we define a 'quicksort' function that performs quicksort on an array using a callback function compare to compare elements. The 'partition' function is used to partition the array into two halves based on the pivot element, and 'swap' function is used to swap elements in the array. The 'intcmp' function is an example of a callback function that takes two integer pointers as input and returns their difference.
In 'main' function, we define an integer array, call quicksort with the array, its size, the size of each element, and the ‘intcmp’ function as arguments, and print the results before and after sorting.
Flowchart:
C Programming Code Editor:
Previous: Shuffle the elements of an array.
What is the difficulty level of this exercise?
Test your Programming skills with w3resource's quiz.
- Weekly Trends and Language Statistics
- Weekly Trends and Language Statistics