Search
 
SCRIPT & CODE EXAMPLE
 

CPP

quicksort geeksforgeeks

/* C++ implementation of QuickSort */
#include <bits/stdc++.h>
using namespace std;
 
// A utility function to swap two elements
void swap(int* a, int* b)
{
    int t = *a;
    *a = *b;
    *b = t;
}
 
/* This function takes last element as pivot, places
the pivot element at its correct position in sorted
array, and places all smaller (smaller than pivot)
to left of pivot and all greater elements to right
of pivot */
int partition (int arr[], int low, int high)
{
    int pivot = arr[high]; // pivot
    int i = (low - 1); // Index of smaller element and indicates the right position of pivot found so far
 
    for (int j = low; j <= high - 1; j++)
    {
        // If current element is smaller than the pivot
        if (arr[j] < pivot)
        {
            i++; // increment index of smaller element
            swap(&arr[i], &arr[j]);
        }
    }
    swap(&arr[i + 1], &arr[high]);
    return (i + 1);
}
 
/* The main function that implements QuickSort
arr[] --> Array to be sorted,
low --> Starting index,
high --> Ending index */
void quickSort(int arr[], int low, int high)
{
    if (low < high)
    {
        /* pi is partitioning index, arr[p] is now
        at right place */
        int pi = partition(arr, low, high);
 
        // Separately sort elements before
        // partition and after partition
        quickSort(arr, low, pi - 1);
        quickSort(arr, pi + 1, high);
    }
}
 
/* Function to print an array */
void printArray(int arr[], int size)
{
    int i;
    for (i = 0; i < size; i++)
        cout << arr[i] << " ";
    cout << endl;
}
 
// Driver Code
int main()
{
    int arr[] = {10, 7, 8, 9, 1, 5};
    int n = sizeof(arr) / sizeof(arr[0]);
    quickSort(arr, 0, n - 1);
    cout << "Sorted array: 
";
    printArray(arr, n);
    return 0;
}
 
// This code is contributed by rathbhupendra
Comment

PREVIOUS NEXT
Code Example
Cpp :: length of number c++ 
Cpp :: c++ initialize static variable 
Cpp :: define in cpp 
Cpp :: cuda shared variable 
Cpp :: how to say hello world in c++ 
Cpp :: c++ multiple inheritance 
Cpp :: min element in vector c++ 
Cpp :: factorial in c++ using recursion 
Cpp :: c++ move semantics for `this` 
Cpp :: c++ pointers and functions 
Cpp :: difference between --a and a-- c++ 
Cpp :: c++ client service ros 
Cpp :: define vector with size and value c++ 
Cpp :: search by value in map in stl/cpp 
Cpp :: convert std vector to array 
Cpp :: How to split a string by Specific Delimiter in C/C++ 
Cpp :: CRED Coins codechef solution in c++ 
Cpp :: find text in string c++ true false 
Cpp :: hello world cc++ 
Cpp :: cpp ignore warning in line 
Cpp :: what library is rand in c++ 
Cpp :: what is the meaning of life and everything in the universe 
Cpp :: Basic Input / Output in C++ 
Cpp :: c ++ program to insert into hashmap 
Cpp :: len in cpp 
Cpp :: c++ memory address 
Cpp :: dangling pointer 
Cpp :: tower of hanoi 
Cpp :: How to see gateway on linux 
Cpp :: unordered_map in c++ 
ADD CONTENT
Topic
Content
Source link
Name
6+7 =