Pagini recente » Cod sursa (job #2824423) | Cod sursa (job #3210395) | Cod sursa (job #2476401) | Cod sursa (job #510710) | Cod sursa (job #1077505)
#include <iostream>
#include <fstream>
using namespace std;
int a[100],n;
void merge(int p,int q,int r)
{
int i=p,j=q+1,k=0,c[100];
while((i<=q)&&(j<=r))
{
if(a[i]<a[j])
{
c[k]=a[i];
k++;
i++;
}
else
{
c[k]=a[j];
k++;
j++;
}
}
while(i<=q)
{
c[k]=a[i];
k++;
i++;
}
while(j<=r)
{
c[k]=a[j];
k++;
j++;
}
i=0;
while(i<k)
{
a[p+i]=c[i];
i++;
}
}
void mergesort(int p,int r)
{
if(p<r)
{
int q=(p+r)/2;
mergesort(p,q);
mergesort(q+1,r);
merge(p,q,r);
}
}
int main()
{
int i,p=0,r;
ifstream f("algsort.in");
ofstream g("algsort.out");
f>>n;
r=n-1;
for(i=0;i<n;i++)
f>>a[i];
mergesort(0,n-1);
for(i=0;i<n;i++)
g<<a[i]<<" ";
f.close();
g.close();
return 0;
}