Pagini recente » Cod sursa (job #2726069) | Cod sursa (job #2380500) | Cod sursa (job #1744176) | Cod sursa (job #2660169) | Cod sursa (job #2743867)
#include<fstream>
#include<algorithm>
#include<cmath>
using namespace std;
ifstream fin("algsort.in");
ofstream fout("algsort.out");
int v[500005];
int n,m,i,j,k,maxim,s,sum,p,u,aux;
void quicksort(int i,int j){
if(i>=j)
return;
int ok;
int t=i;
int u=j;
int poz=i;
while(t<u){
if(poz==t){
ok=0;
for(int g=u;g>=t;g--){
if(v[g]<v[t]){
swap(v[g],v[t]);
u=g;
poz=u;
t++;
ok=1;
break;
}
}
if(ok==0){
poz=t;
u=poz;
}
}
else{
ok=0;
for(int g=t;g<=u;g++){
if(v[g]>v[u]){
swap(v[g],v[u]);
t=g;
poz=t;
u--;
ok=1;
break;
}
}
if(ok==0){
poz=u;
t=poz;
}
}
}
quicksort(i,poz-1);
quicksort(poz+1,j);
}
int main(){
fin>>n;
for(i=1;i<=n;i++){
fin>>v[i];
}
for(i=1;i<=n;i++){
k=1+rand()%n;
aux=v[i];
v[i]=v[k];
v[k]=aux;
}
quicksort(1,n);
for(i=1;i<=n;i++)
fout<<v[i]<<" ";
return 0;
}