#include <bits/stdc++.h>
using namespace std;
int ok=0, z=0;
int diag(int k, int v[])
{int i;
for(i=1;i<k;i++)
if(abs(v[k]-v[i])==(k-i))
return 0;
return 1;
}
void afisare(int n, int v[], int viz[])
{int i,j;
for(i=1;i<=n;i++)
{for(j=1;j<=n;j++)
{if(v[i]==j) cout<<v[i]<<" ";
}
}
}
void bkt(int k, int v[], int n, int viz[])
{int i;
if(k==n+1) {if(ok==0) afisare(n,v,viz); ok=1; z++;}
for(i=1;i<=n;i++)
{
v[k]=i;
if(viz[i]==0 && diag(k,v))
{
viz[i]=1;
bkt(k+1,v,n,viz);
viz[i]=0;
}
}
}
int main()
{int viz[15]={0},n,v[15];
cin>>n;
bkt(1,v,n,viz);
cout<<"\n"<<z;
return 0;
}