Pagini recente » Cod sursa (job #1083563) | Cod sursa (job #37677) | Cod sursa (job #3181013) | Cod sursa (job #151971) | Cod sursa (job #370681)
Cod sursa(job #370681)
#include<fstream.h>
long a[500000],n,i;
void ex(long i,long j)
{
long aux=a[i];
a[i]=a[j];
a[j]=aux;
}
void qs(long i,long j)
{
long s=i,d=j,piv=a[(i+j)/2];
while(s<=d)
{
while(a[s]<piv)s++;
while(a[d]>piv)d--;
if(s<=d)
{
ex(s,d);
s++;
d--;
}
}
if(i<d) qs(i,d);
if(s<j) qs(s,j);
}
int main()
{
ifstream f("algsort.in");
ofstream g("algsort.out");
f>>n;
for(i=1;i<=n;i++)f>>a[i];
qs(1,n);
for(i=1;i<=n;i++)g<<a[i]<<' ';
return 0;
}