#include<bits/stdc++.h>
using namespace std;
int n,a[100],c[100];
void asd(int l,int r){   
    if(l>=r){
        return;
    } 
    int mid=(l+r)/2;
    merge1(l,mid);
	merge1(mid+1,r);
	int i=l,j=mig,k=1;
	while(i<=mid&&j<=r){
        if(a[i]<a[j]){
            c[k++]=a[i++];
        }else{
            c[k++]=a[j++];
        }
    }
	 while(i<=mid){
        c[k++]=a[i++];
    }
    while(j<=r){
        c[k++]=a[j++];
    }
    for(int i=1;i<=r-l+1;i++){
        a[l+i-1]=c[i];
    } 
} 
int main(){
    cin>>n;
    for(int i=1;i<=n;i++){
        cin>>a[i];
    }   asd(1,n);
    for(int i=1;i<=n;i++){
        cout<<a[i]<<' ';
    }
} 
/**************************************************************
	Problem: 1010
	User: caijiajie
	Language: C++
	Result: Compile Error
****************************************************************/