#include <iostream>
#include <cstddef>
#include <future>
// Swap two elements - Utility function
void swap(int* a, int* b)
{
int t = *a;
*a = *b;
*b = t;
}
// partition the array using last element as pivot
int partition (int arr[], int low, int high)
{
int pivot = arr[high]; // pivot
int i = (low - 1);
for (int j = low; j <= high- 1; j++)
{
//if current element is smaller than pivot, increment the low element
//swap elements at i and j
if (arr[j] <= pivot)
{
i++; // increment index of smaller element
swap(&arr[i], &arr[j]);
}
}
swap(&arr[i + 1], &arr[high]);
return (i + 1);
}
//quicksort algorithm
void quickSort(int arr[], int low, int high)
{
if (low < high)
{
//partition the array
int pivot = partition(arr, low, high);
//sort the sub arrays independently
std::future<void> subtask = std::async(std::launch::async, quickSort, arr, low, pivot - 1);
quickSort(arr, pivot + 1, high);
subtask.get(); // synchronously wait for the async task to finish
}
}
template<std::size_t N>
void displayArray(const int(&arr)[N])
{
for (int value : arr)
std::cout << value << ' ';
std::cout << '\n';
}
int main()
{
using namespace std;
int arr[] = {12,23,3,43,51,35,19,45};
int n = sizeof(arr)/sizeof(arr[0]);
cout<<"Input array"<<endl;
displayArray(arr);
cout<<endl;
quickSort(arr, 0, n-1);
cout<<"Array sorted with quick sort"<<endl;
displayArray(arr);
return 0;
}
I2luY2x1ZGUgPGlvc3RyZWFtPgojaW5jbHVkZSA8Y3N0ZGRlZj4KI2luY2x1ZGUgPGZ1dHVyZT4KCi8vIFN3YXAgdHdvIGVsZW1lbnRzIC0gVXRpbGl0eSBmdW5jdGlvbiAgCnZvaWQgc3dhcChpbnQqIGEsIGludCogYikgCnsgCiAgICBpbnQgdCA9ICphOyAKICAgICphID0gKmI7IAogICAgKmIgPSB0OyAKfSAKICAgCi8vIHBhcnRpdGlvbiB0aGUgYXJyYXkgdXNpbmcgbGFzdCBlbGVtZW50IGFzIHBpdm90CmludCBwYXJ0aXRpb24gKGludCBhcnJbXSwgaW50IGxvdywgaW50IGhpZ2gpIAp7IAogICAgaW50IHBpdm90ID0gYXJyW2hpZ2hdOyAgICAvLyBwaXZvdCAKICAgIGludCBpID0gKGxvdyAtIDEpOyAgIAogICAKICAgIGZvciAoaW50IGogPSBsb3c7IGogPD0gaGlnaC0gMTsgaisrKSAKICAgIHsgCiAgICAgICAgLy9pZiBjdXJyZW50IGVsZW1lbnQgaXMgc21hbGxlciB0aGFuIHBpdm90LCBpbmNyZW1lbnQgdGhlIGxvdyBlbGVtZW50CiAgICAgICAgLy9zd2FwIGVsZW1lbnRzIGF0IGkgYW5kIGoKICAgICAgICBpZiAoYXJyW2pdIDw9IHBpdm90KSAKICAgICAgICB7IAogICAgICAgICAgICBpKys7ICAgIC8vIGluY3JlbWVudCBpbmRleCBvZiBzbWFsbGVyIGVsZW1lbnQgCiAgICAgICAgICAgIHN3YXAoJmFycltpXSwgJmFycltqXSk7IAogICAgICAgIH0gCiAgICB9IAogICAgc3dhcCgmYXJyW2kgKyAxXSwgJmFycltoaWdoXSk7IAogICAgcmV0dXJuIChpICsgMSk7IAp9IAogICAKLy9xdWlja3NvcnQgYWxnb3JpdGhtCnZvaWQgcXVpY2tTb3J0KGludCBhcnJbXSwgaW50IGxvdywgaW50IGhpZ2gpIAp7IAogICAgaWYgKGxvdyA8IGhpZ2gpIAogICAgeyAKICAgICAgICAvL3BhcnRpdGlvbiB0aGUgYXJyYXkgCiAgICAgICAgaW50IHBpdm90ID0gcGFydGl0aW9uKGFyciwgbG93LCBoaWdoKTsgCiAgIAogICAgICAgIC8vc29ydCB0aGUgc3ViIGFycmF5cyBpbmRlcGVuZGVudGx5IAogICAgICAgIHN0ZDo6ZnV0dXJlPHZvaWQ+IHN1YnRhc2sgPSBzdGQ6OmFzeW5jKHN0ZDo6bGF1bmNoOjphc3luYywgcXVpY2tTb3J0LCBhcnIsIGxvdywgcGl2b3QgLSAxKTsKICAgICAgICBxdWlja1NvcnQoYXJyLCBwaXZvdCArIDEsIGhpZ2gpOyAKICAgICAgICBzdWJ0YXNrLmdldCgpOyAvLyBzeW5jaHJvbm91c2x5IHdhaXQgZm9yIHRoZSBhc3luYyB0YXNrIHRvIGZpbmlzaAogICAgfSAKfQoKdGVtcGxhdGU8c3RkOjpzaXplX3QgTj4Kdm9pZCBkaXNwbGF5QXJyYXkoY29uc3QgaW50KCZhcnIpW05dKQp7Cglmb3IgKGludCB2YWx1ZSA6IGFycikKCSAgICBzdGQ6OmNvdXQgPDwgdmFsdWUgPDwgJyAnOwoJc3RkOjpjb3V0IDw8ICdcbic7Cn0KCmludCBtYWluKCkgCnsgCgl1c2luZyBuYW1lc3BhY2Ugc3RkOwoKICAgIGludCBhcnJbXSA9IHsxMiwyMywzLDQzLDUxLDM1LDE5LDQ1fTsgCiAgICBpbnQgbiA9IHNpemVvZihhcnIpL3NpemVvZihhcnJbMF0pOyAKICAgIGNvdXQ8PCJJbnB1dCBhcnJheSI8PGVuZGw7CiAgICBkaXNwbGF5QXJyYXkoYXJyKTsKICAgIGNvdXQ8PGVuZGw7CiAgICBxdWlja1NvcnQoYXJyLCAwLCBuLTEpOyAKICAgIGNvdXQ8PCJBcnJheSBzb3J0ZWQgd2l0aCBxdWljayBzb3J0Ijw8ZW5kbDsgCiAgICBkaXNwbGF5QXJyYXkoYXJyKTsgCiAgICByZXR1cm4gMDsgCn0K