Pagini recente » Cod sursa (job #723166) | Cod sursa (job #1769633) | Cod sursa (job #1235161) | Cod sursa (job #1844626) | Cod sursa (job #2743853)
#include<fstream>
#include<algorithm>
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;
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];
}
quicksort(1,n);
for(i=1;i<=n;i++)
fout<<v[i]<<" ";
return 0;
}