#include<bits/stdc++.h>
using namespace std;
int n,a[101];
bool vis[100];
void dfs(int g,string s)
{
    if(g>n)
    {
        printf("%s\n", s.c_str());
        return;
    }
    for(int i=1;i<=n;i++)
    {
        if(!vis[i])
        {
            vis[i]=1;
            dfs(g+1,s+char(a[i]+'0')+' ');
            vis[i]=0;
        }
    }
}
int main()
{
    cin>>n;
    for(int i=1;i<=n;i++)
    {
        cin>>a[i];
    }
    sort(a+1,a+n+1); 
    dfs(1,"");
}
/**************************************************************
	Problem: 1685
	User: jiangzhenghang
	Language: C++
	Result: Accepted
	Time:36 ms
	Memory:2076 kb
****************************************************************/