olegfresi ha scritto:Ah ok, adesso ho capito perchè, m si può implementare un sistema in modo che l'utente inserisca proprio il primo e l'ultimo valore dell'array ma questi vengano poi associati agli indici e l'algoritmo lavora solo con gli indici?
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);
}
si è la funzione stampaArray che me li stampa disordinati dopo aver chiamato la mergeSort
Super Squirrel ha scritto:In ogni caso a scanso di equivoci, metti tutto in un solo file compilabile e riporta il codice qui sul forum insieme a quello che è l'output del programma e l'output che invece ti aspetteresti.
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 v[]={ 4, 7, 2, 9, 3, 12 };
cout << "Ecco l'array disordinato: " << endl;
stampaArray(v, 6);
cout << "Ecco l'array ordinato con quick sort: " << endl;
quickSort(v, 0, 5);
stampaArray(v, 6);
system("pause");
return 0;
}
Visitano il forum: Nessuno e 1 ospite