输入一个自然数N(2<N<9),要求输出如下的魔方阵,即边长为NN,元素取值为1至NN,1在左上角,呈顺时针方向依次放置各元素。
N=3时:
1 2 3
8 9 4
7 6 5
【输入样例】
4
【输出样例】输出内容为:
1 2 3 4
12 13 14 5
11 16 15 6
10 9 8 7
import java.util.Scanner;
public class java3_6 {
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner input=new Scanner(System.in);
System.out.println("请输入n:");
int n=input.nextInt();
int num[][]=new int[n][n];
for(int i=0;i<n;i++)
{
for(int j=0;j<n;j++)
{
num[i][j]=0;
}
}
int left=0,right=n-1;
for(int i=0;i<n*n;i++)
{
if(i<n)
{
num[0][i]=i+1;
continue;
}
while(right+1<n&&num[left][right+1]==0)
{
num[left][right+1]=i+1;
++right;
++i;
}
while(left+1<n&&num[left+1][right]==0)
{
num[left+1][right]=i+1;
++left;
i++;
}
while(right-1>=0&&num[left][right-1]==0)
{
num[left][right-1]=i+1;
--right;
i++;
}
while(left-1>=0&&num[left-1][right]==0)
{
num[left-1][right]=i+1;
--left;
i++;
}
--i;
}
for(int o=0;o<n;o++)
{
for(int j=0;j<n;j++)
{
System.out.print("\t"+num[o][j]);
}
System.out.println("");
}
input.close();
}
}