Pagini recente » Monitorul de evaluare | Monitorul de evaluare | Diferente pentru problema/negot intre reviziile 4 si 3 | Istoria paginii problema/munte2 | Cod sursa (job #1868723)
#include <bits/stdc++.h>
using namespace std;
ifstream f("algsort.in");
ofstream g("algsort.out");
int n,v[500010];
void quick_sort(int,int);
int main()
{
f>>n;
srand(time(0));
for(int i=1;i<=n;i++)
f>>v[i];
quick_sort(1,n);
for(int i=1;i<=n;i++)
g<<v[i]<<' ';
return 0;
}
void quick_sort(int lo,int hi)
{
if(lo>=hi)return;
int st=lo,dr=hi,mi;
mi=st+rand()%(dr-st+1);
mi=v[mi];
do
{
while(v[st]<mi)st++;
while(v[dr]>mi)dr--;
if(st<=dr){swap(v[st],v[dr]);st++;dr--;}
}while(st<=dr);
if(dr>lo)quick_sort(lo,dr);
if(st<hi)quick_sort(st,hi);
}