/*
* 【求奇数阶幻方】
* 每一个数放在前一个数的右上一格
*/
package test1;
public class demo {
public static void main(String[] args)
{
int j=3;
int a[][]=new int[j][j];
for(int b = 0;b<j;b++)
{
for(int d=0;d<j;d++)
{
a[b][d]=0;
}
}
int r=0;
int c=j/2;
a[r][c]=1; //最小的数(这里为1)一般放在第一行的中间
for(int i=2;i<=j*j;i++)
{
r=r-1; //默认在前一个数的右上方
c=c+1;
if(r<0 && c<=j-1) //如果这个数所要放的格子已经超出了顶行,就把它放在底行,仍然要放在右上方
{
r=j-1;
}
if(c>j-1 && r>=0) //如果这个数所要放的格子已经超出了最右列,就把它放在最左列,仍然要放在右上方
{
c=0;
}
if(r<0 && c>j-1) //如果这个数所要放的格子已经超出了顶行且超出了最右列,把它放在前一个数的下一行同一列的格内
{
r=r+2;
c=c-1;
}
if(a[r][c]!=0) //如果这个数所要放的格子已经有数填入,把它放在前一个数的下一行同一列的格内
{
r=r+2;
c=c-1;
}
a[r][c]=i;
}
for(int e=0;e<j;e++)
{
for(int f=0;f<j;f++)
{
System.out.print(a[e][f]+" ");
if(f==j-1)
System.out.println("\n");
}
}
}
}
* 【求奇数阶幻方】
* 每一个数放在前一个数的右上一格
*/
package test1;
public class demo {
public static void main(String[] args)
{
int j=3;
int a[][]=new int[j][j];
for(int b = 0;b<j;b++)
{
for(int d=0;d<j;d++)
{
a[b][d]=0;
}
}
int r=0;
int c=j/2;
a[r][c]=1; //最小的数(这里为1)一般放在第一行的中间
for(int i=2;i<=j*j;i++)
{
r=r-1; //默认在前一个数的右上方
c=c+1;
if(r<0 && c<=j-1) //如果这个数所要放的格子已经超出了顶行,就把它放在底行,仍然要放在右上方
{
r=j-1;
}
if(c>j-1 && r>=0) //如果这个数所要放的格子已经超出了最右列,就把它放在最左列,仍然要放在右上方
{
c=0;
}
if(r<0 && c>j-1) //如果这个数所要放的格子已经超出了顶行且超出了最右列,把它放在前一个数的下一行同一列的格内
{
r=r+2;
c=c-1;
}
if(a[r][c]!=0) //如果这个数所要放的格子已经有数填入,把它放在前一个数的下一行同一列的格内
{
r=r+2;
c=c-1;
}
a[r][c]=i;
}
for(int e=0;e<j;e++)
{
for(int f=0;f<j;f++)
{
System.out.print(a[e][f]+" ");
if(f==j-1)
System.out.println("\n");
}
}
}
}