【问题描述】
输入一个自然数N(N属于2到15),要求输出如下的魔方阵,即边长为N*N,元素取值为1至N*N,1在左上角,呈顺时针方向依次放置各元素。
N=3时:
1 2 3
8 9 4
7 6 5
【输入形式】
从标准输入读取一个整数N。
【输出形式】
向标准输出打印结果。输出符合要求的方阵,每个数字占5个字符宽度,向右对齐,在每一行末均输出一个回车符。
【输入样例】
4
【输出样例】
1 2 3 4
12 13 14 5
11 16 15 6
10 9 8 7
#include <iostream.h>
#include <iomanip.h>
#define Max 15
void cube(int n,int a[Max][Max])
{
int i;
for(i=0;i<n/2;i++)
{
int x=i,y=i,k=1;
while(y<n-i-1)a[x][y++]=k++;
while(x<n-i-1)a[x++][y]=k++;
while(y>i)a[x][y--]=k++;
while(x>i)a[x--][y]=k++;
}
if(n%2!=0)
a[n/2][n/2]=n*n;
}
int main()
{
int N;
cin>>N;
int a[Max][Max];
cube(N,a);
for(int i=0;i<N;i++)
{
for(int j=0;j<N;j++)
cout<<setw(5)<<a[i][j];
cout<<endl;
}
return 0;
}
```求大佬帮忙找出哪错了?