#include <iostream>
#include <cstdlib>
#include <string>
using namespace std;
void stampaArray(int arr[], int l)
{
for (int i = 0; i < l; i++)
cout << arr[i] << endl;
}
void quickSort(int arr[], int inizio, int fine)
{
int i = inizio, j = fine, tmp;
int pivot = arr[(inizio + fine) / 2];
cout << pivot << endl;
while (i <= j)
{
while (arr[i] < pivot)
i++;
while (arr[j] > pivot)
j--;
if (i <= j)
{
tmp = arr[i];
arr[i] = arr[j];
arr[j] = tmp;
i++;
j--;
}
};
if (inizio < j)
quickSort(arr, inizio, j);
if (i < fine)
quickSort(arr, i, fine);
}
int main()
{
int v3[]={ 4, 7, 2, 9, 3, 12 };
cout << "Ecco l'array disordinato: " << endl;
stampaArray(v3, 6);
cout << "Ecco l'array ordinato con quick sort: " << endl;
quickSort(v3, 0, 5);
stampaArray(v3, 6);
system("pause");
return 0;
}
#include <iostream>
#include <cstdlib>
#include <string>
using namespace std;
void stampaArray(int arr[], int l)
{
for (int i = 0; i < l; i++)
cout << arr[i] << endl;
}
void quickSort(int arr[], int inizio, int fine)
{
int i = inizio, j = fine, tmp;
int pivot = arr[(inizio + fine) / 2];
cout << "pivot: " << pivot << endl;
while (i <= j)
{
while (arr[i] < pivot)
i++;
while (arr[j] > pivot)
j--;
if (i <= j)
{
tmp = arr[i];
arr[i] = arr[j];
arr[j] = tmp;
i++;
j--;
}
};
if (inizio < j)
quickSort(arr, inizio, j);
if (i < fine)
quickSort(arr, i, fine);
}
int main()
{
int v3[]={ 4, 7, 2, 9, 3, 12 };
cout << "Ecco l'array disordinato: " << endl;
stampaArray(v3, 6);
quickSort(v3, 0, 5);
cout << "Ecco l'array ordinato con quick sort: " << endl;
stampaArray(v3, 6);
system("pause");
return 0;
}
Visitano il forum: Nessuno e 1 ospite