#include<stdio.h>//我用的是一层一层将1,2,3......放入数组最后输出的方法
int main()
{
int n,i,j;
scanf("%d",&n);
int count=1;//count的作用是实现螺旋中12345递增,与下文的count++一起实现
int a[1000][1000];//定义1000是因为数组不能用变量定义
for(i=0;i<n/2;i++)//这边可以用特殊值理解,例如输入5要螺旋3层
{
for(j=i;j<=n-2-i;j++)
{
a[i][j]=count++;
}//上
for(j=i;j<=n-2-i;j++)
{
a[j][n-1-i]=count++;
}//右
for(j=n-1-i;j>=i;j--)
{
a[n-1-i][j]=count++;
}//下
for(j=n-2-i;j>i;j--)
{
a[j][i]=count++;
}//左
}
if(n%2!=0)a[n/2][n/2]=n*n;//如果n是奇数,最中间的那个数要自己输入
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
printf("%3d",a[i][j]);
}//输出
printf("\n");//注意需要换行(每n个
}
}
PTA作业 螺旋数组
最新推荐文章于 2024-07-24 22:13:06 发布