Pagini recente » Cod sursa (job #83671) | Cod sursa (job #188094) | Cod sursa (job #1293703) | Cod sursa (job #142770) | Cod sursa (job #2983957)
#include <bits/stdc++.h>
using namespace std;
ifstream f("algsort.in");
ofstream g("algsort.out");
int n, v[500005];
void afisare(){
for(int i=1;i<=n;++i){
g << v[i] << " ";
}
}
void interclasare(int st, int dr){
int k=0, aux[500001];
int mij=(st+dr)/2;
int i=st, j=mij+1;
while(i<=mij && j<=dr){
if(v[i]<v[j]){
aux[++k]=v[i];
i++;
}
else{
aux[++k]=v[j];
j++;
}
}
while(i<=mij){
aux[++k]=v[i];
i++;
}
while(j<=dr){
aux[++k]=v[j];
j++;
}
k=1;
for(int i=st;i<=dr;++i){
v[i]=aux[k];
k++;
}
}
void msort(int st, int dr){
if(dr-st>=1){
int mij=(st+dr)/2;
msort(st, mij);
msort(mij+1, dr);
interclasare(st, dr);
}
}
int main(){
f >> n;
for(int i=1;i<=n;++i){
f >> v[i];
}
msort(1, n);
afisare();
return 0;
}