Pagini recente » Cod sursa (job #1705884) | Cod sursa (job #1416015) | Cod sursa (job #1836191) | Cod sursa (job #2607105) | Cod sursa (job #3254143)
#include <fstream>
#include <time.h>
using namespace std;
ifstream cin("algsort.in");
ofstream cout("algsort.out");
int v[500002],n, k;
int quicksort(int st, int dr)
{
if(st<dr) ///secventa are cel putin doua elemente
{
int i=st, j=dr, mod=0;
int poz=rand()%(dr-st+1)+st;
swap(v[st], v[poz]);
while(i<j)
{
if(v[i] > v[j])
{
swap(v[i],v[j]); ///interschimb valorile
mod=1-mod; ///schimb modul de lucru
}
i=i+mod;
j=j-(1-mod);
}
///am ajuns in situatia i==j si pivotul este plasat aici
quicksort(st,i-1);
quicksort(i+1,dr);
}
}
int main()
{
cin>>n;
for(int i=1;i<=n;i++)
cin>>v[i];
srand(time(NULL));
quicksort(1,n);
for(int i=1;i<=n;i++)
cout<<v[i]<<" ";
return 0;
}