#include<stdio.h>
int main()
{
int a[100][100]={0};
int i,j,n,k=1;
scanf("%d",&n);
i=0;
j=n/2;
for(k=1;k<=n*n;k++)
{
a[i][j]=k;
if(i==0)
i=n-1;
else
i=i-1;
if(j==n-1)
j=0;
else
j=j+1;
if(a[i][j]==0)
continue;
if(a[i][j]!=0)
{
if(i!=0)
i=i-1;
else
i=n-1;
if(j=0)
j=j+n-1;
else
j=j-1;
}
}
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
printf("%4d",a[i][j]);
printf("\n");
} return 0;
}
你的错误在于当你计算完下一个i,j的预期位置后,i,j就已经不再是当前的i和j了。你在修改后的i和j上做了下移,而题目中要求的是在修改前的i和j上做下移。
给个提示,当你想实现i-1且当i=0时切换为n-1的动作,可以用(i+n-1)%n来实现,同样的,往右边移动的j也可以用(j+1)%n来实现
这题脑袋会做歪掉