#include <iostream>
using namespace std;
const int N = 1000010;
bool bj[N];
int jl[N];
int n;
void dfs(int x)
{
if( x==n)
{
for(int i=0;i<n;i++) printf("%d ",jl[i]);
puts("");
return ;
}
else
{
for(int i=1;i<=n;i++)
{
if(!bj[i])
{
bj[i]=true;
jl[x]=i;
dfs(x+1);
bj[i]=false;
}
}
}
}
int main()
{
cin>>n;
dfs(0);
return 0;
}