w3resource

C Exercises: Quick sort algorithm

C Programming Searching and Sorting Algorithm: Exercise-6 with Solution

Write a C program to sort a list of elements using the quick sort algorithm.

Note: Quick sort is a comparison sort, meaning that it can sort items of any type for which a "less-than" relation (formally, a total order) is defined.
Read n values into array and Sort using Quick Sort.

Visual presentation - Quick Sort algorithm:

C programming Quick sort algorithm part-1

C programming Quick sort algorithm part-2

Sample Solution:

Sample C Code:

#include<stdio.h>
int n; // Global variable to store the number of elements
int main() {
    int arr[30], l, r, i;
    // Function declaration
    void quick_sort(int arr[], int low, int high);
    // Input the number of elements
    printf("\nInput number of elements: ");
    scanf("%d", &n);
    // Input array values one by one
    printf("\nInput array values one by one: ");
    for (i = 0; i < n; i++)
        scanf("%d", &arr[i]);
    l = 0;
    r = n - 1;
    // Call the quick_sort function to sort the array
    quick_sort(arr, l, r);
    // Display the quick sorted array
    printf("\nThe quick sorted array is: ");
    for (i = 0; i < n; i++)
        printf(" %d", arr[i]);
    printf("\n");
    return 0;
}

// Function to perform quick sort on array arr[] from index low to high
void quick_sort(int arr[], int low, int high) {
    int temp, left, right, x, k;
    // Base case: If low is greater than or equal to high, return
    if (low >= high)
        return;
    else {
        x = arr[low];
        right = low + 1;
        left = high;
        // Partition the array
        while (right <= left) {
            // Find an element greater than x on the right side
            while (arr[right] < x && right <= high) {
                right++;
            }
            // Find an element smaller than x on the left side
            while (arr[left] > x && left > low) {
                left--;
            }
            // Swap the elements if right is less than left
            if (right < left) {
                temp = arr[right];
                arr[right] = arr[left];
                arr[left] = temp;
                right++;
                left--;
            }
        }
        // Swap the pivot (x) with the element at left
        arr[low] = arr[left];
        arr[left] = x;
        // Recursive calls for the two subarrays
        quick_sort(arr, low, left - 1);
        quick_sort(arr, left + 1, high);
    }
}

Sample Input:

3
12
15
56

Sample Output:

Input number of elements:  
Input  array values one by one: 
The quick sorted array is:   12 15 56

Flowchart:

Flowchart: C Programming - Quick sort

C Programming Code Editor:

Previous: Write a C program to sort numbers using heap algorithm(MAX heap).
Next: Write a C program to sort a list of elements using the radix sort algorithm.

What is the difficulty level of this exercise?

Test your Programming skills with w3resource's quiz.



Become a Patron!

Follow us on Facebook and Twitter for latest update.

It will be nice if you may share this link in any developer community or anywhere else, from where other developers may find this content. Thanks.

https://w3resource.com/c-programming-exercises/searching-and-sorting/c-search-and-sorting-exercise-7.php