仅供参考,望采纳~
#include<stdio.h>
int main(void)
{
int n;
scanf("%d",&n);
int p[n][n];
int i,s=1,x=n,z=1,y=n,k=1;//s~y上下左右边界
while(s<=x&&z<=y)
{
for(i=z;i<=y;i++)
{p[s][i]=k++;}
for(i=s+1;i<=x;i++)
{p[i][y]=k++;}
for(i=y-1;i>=z&&s<y;i--)
{p[x][i]=k++;}
for(i=x-1;i>s&&z<y;i--)
{p[i][z]=k++;}
s++;x--;z++;y--;
}
for(i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
{
printf("%4d",p[i][j]);
}
printf("\n");
}
return 0;
}