文件详细信息

下载本文件

本文件的大小为 590 字节。

#include<cstdio>
const int maxn=300;
int n,a[maxn+1][maxn+1];
int main(){
	freopen("squ.in","r",stdin);
	freopen("squ.out","w",stdout);
	scanf("%d",&n);
	if(n==2){
		puts("-1");
		return 0;
	}
	if((n&1)==0){
		for(int v=1;v<n;v++)
			for(int i=1;i<n;i++)
				a[i][(n-1+v-i)%(n-1)+1]=v;
		a[1][n]=a[n][n-1]=a[1][n-1],a[1][n-1]=n;
		for(int i=2;i<n;i++)a[i][n]=a[n][i-1]=a[i][i-1],a[i][i-1]=n;
		a[n][n]=n;
	}else{
		for(int i=1;i<=n;i++)
			for(int j=1;j<=n;j++)
				a[i][j]=(i+j-2)%n+1;
	}
	for(int i=1;i<=n;i++)
		for(int j=1;j<=n;j++)
			printf("%d%c",a[i][j],j!=n?' ':'\n');
	return 0;
}