Pagini recente » Cod sursa (job #761967) | Cod sursa (job #2498995) | Cod sursa (job #1169451) | Cod sursa (job #2339430) | Cod sursa (job #2292822)
#include <iostream>
#include <fstream>
#include <algorithm>
using namespace std;
int partitie( int *v, int st, int dr)
{
int p = v[dr], i, j, aux;
i = st-1;
for ( j = st; j < dr ; j++)
{
if ( v[j] <= p )
{
i++;
swap ( v[i], v[j]);
}
}
swap (v[i+1],v[dr]);
return (i+1);
}
void quickSort ( int *v, int st, int dr)
{
if( st >= dr)
return;
int p = partitie ( v, st ,dr);
quickSort(v, st, p-1);
quickSort(v, p+1, dr);
}
int main()
{
int n, *v, i;
ifstream in("algsort.in");
ofstream out ("algsort.out");
in >> n;
v = new int [n+1];
for (i = 0 ; i < n ; i++)
in >> v[i];
quickSort (v, 0, n-1);
for (i = 0; i < n; i++)
out << v[i] << " ";
in.close();
out.close();
return 0;
}