#include<algorithm>
using namespace std;
void quick_sort(int *s, int l, int r)
{
if (l < r)
{
//Swap(s[l], s[(l + r) / 2]); //将中间的这个数和第一个数交换 参见注1
int i = l, j = r, x = s[l];
while (i < j)
{
while(i < j && s[j] >= x) // 从右向左找第一个小于x的数
j--;
if(i < j)
{
s[i] = s[j];
i++;
}
while(i < j && s[i] < x) // 从左向右找第一个大于等于x的数
i++;
if(i < j) {
s[j] = s[i];
j--;
}
}
s[i] = x;
quick_sort(s, l, i - 1); // 递归调用
quick_sort(s, i + 1, r);
}
}
int main()
{
int n,i,t=0;
cin>>n;
int a[n];
for(i=1;i<=n;i++)
{
cin>>a[i];
}
quick_sort(a,1,n);
for(i=1;i<=n;i++)
{
cout<<a[i]<<" ";
}
return 0;
}