#include<iostream> using namespace std; int N; int A[500][500]; main() { cin>>N; for(int i=0;i<N;i++)A[i][i]=i+1; for(int i=0;i<N-1;i++) { int t=A[i][i]; for(int j=i+1;j<N;j++) { while(true) { bool found=false; for(int k=0;k<N;k++)if(A[i][k]==t||A[k][j]==t) { found=true; break; } if(!found) { break; } t=t%N+1; } A[i][j]=A[j][i]=t; } } for(int i=0;i<N;i++) { for(int j=0;j<N;j++)cout<<A[i][j]<<(j+1==N?'\n':' '); } }