这个是可以随意生成不同大小的九宫格,相对会复杂一点不过大体算法是一样的
// 定义 N 为九宫格的行列数,需要输入思路:
第一行(数组第0行)的正中间放入1;(a[0][1]=1)
下一个数总是放在放一个数的右上角45°,实际为以下两种情况:
行越界:把这个数放到同列的末行
列越界:把这个数放到同行的首列
.如果遇到n的整数倍数,则放到上个数的正下方,实际为以下两种情况:行列同时越界
冲突(位置上已经有了数字)
代码:
int[][] nine= new int[n][n]; //定义二位数组,默认赋0值
int row = 0,col=n/2; //行列赋初值
for(int i=1;i<=n*n;i++){
nine[row][col]=i;
row--;
col++;
//行列同时越界:放到上个数的正下方
if(row<0&&col>=n){
row+=2;
col--;
} // 行越界:把这个数放到同列的末行
else if(row<0){
row=n-1;
} // 列越界:把这个数放到同行的首列
else if(col>=n){
col=0;
}
//冲突: 放到上个数的正下方
else if(nine[row][col]!=0){
row+=2;
col--;
}
}
//打印 n*n
for(int i=0;i<n;i++){
for(int j=0;j<n;j++){
System.out.print(nine[i][j]+" ");
}
System.out.println();
}
所有情况如下,请采纳
public class Jiugongge {