diff options
author | Santo Cariotti <dcariotti24@gmail.com> | 2020-03-26 23:55:20 +0100 |
---|---|---|
committer | Santo Cariotti <dcariotti24@gmail.com> | 2020-03-26 23:55:20 +0100 |
commit | 88f415f0ae4dea98c759be211e95db4c3396cf50 (patch) | |
tree | 840dbad913981ff322be7068f8a0314466e1dc70 /I_anno | |
parent | bd39a249f8ac8abfc1f1a128479d3438f0cc1594 (diff) |
feat: quicksort algorithm
Diffstat (limited to 'I_anno')
-rw-r--r-- | I_anno/Programmazione_2/quicksort.cc | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/I_anno/Programmazione_2/quicksort.cc b/I_anno/Programmazione_2/quicksort.cc new file mode 100644 index 0000000..a646840 --- /dev/null +++ b/I_anno/Programmazione_2/quicksort.cc @@ -0,0 +1,38 @@ +#include<iostream> + +using namespace std; + +int partition(int A[], int l, int r) { + int x = A[r]; + int i = l-1; + + for(int j = l; j < r; ++j) { + if(A[j] <= x) { + swap(A[++i], A[j]); + } + } + swap(A[++i], A[r]); + return i; +} + +void quicksort(int A[], int l, int r) { + if(l < r) { + int q = partition(A, l, r); + quicksort(A, l, q-1); + quicksort(A, q+1, r); + } +} + +int main() { + int a[] = {7,1,22,3,2,12,27,31,6}; + for(int i = 0; i < 9; ++i) { + cout << a[i] << ' '; + } + cout << endl; + quicksort(a, 0, 9); + for(int i = 0; i < 9; ++i) { + cout << a[i] << ' '; + } + + return 0; +} |