#include<iostream>
using namespace std;
int n,a[10]={0},b[10]={0};
void f(int k)
{int i;
if(k==n+1)
{for(i=1;i<=n;i++)
cout<<a[i]<<" ";
cout<<endl;
}
else for(i=1;i<=n;i++)
if(b[i]==0)
{a[k]=i;
b[i]=1;
f(k+1);
b[i]=0;
}
}
int main(){
cin>>n;
f(1);
return 0;
}
using namespace std;
int n,a[10]={0},b[10]={0};
void f(int k)
{int i;
if(k==n+1)
{for(i=1;i<=n;i++)
cout<<a[i]<<" ";
cout<<endl;
}
else for(i=1;i<=n;i++)
if(b[i]==0)
{a[k]=i;
b[i]=1;
f(k+1);
b[i]=0;
}
}
int main(){
cin>>n;
f(1);
return 0;
}