建立螺旋数组
*1.*首先我们要写一个关于螺旋数组大小,和生成螺旋数组的程序。
它的代码为
int n = 0;
printf(“请输入数组长度:”);
scanf("%d",&n);
int arr[n][n];
int i = 0,j = 0;
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
arr[i][j] = 0;
}
*2.然后我们要使函数变成一个等差数列可以使我们更好的观察结果。
while(num <= nn){
arr[i][j] = num++;
**3.**追后我们要实现螺旋,可以分为4个移动方向。
1.向右移动时。
++j;
//新位置 (i,j)
if(j+1>=n || arr[i][j+1] != 0){
dir++;//改变方向
}
2.向下移动时。
++i;
if(i+1>=n || arr[i+1][j] != 0){
dir++;
}
3.向左移动时。
–j;
if(j0 || arr[i][j-1] != 0){
dir++;
}
4,向上移动时。
–i;
if(arr[i-1][j] != 0){
dir++;
}
4.利用switch函数把他们结合起来
switch(dir%4){
case 0:
++j;
//新位置 (i,j)
if(j+1>=n || arr[i][j+1] != 0){
dir++;//改变方向
}
break;
case 1:
++i;
if(i+1>=n || arr[i+1][j] != 0){
dir++;
}
break;
case 2:
–j;
if(j0 || arr[i][j-1] != 0){
dir++;
}
break;
case 3:
–i;
if(arr[i-1][j] != 0){
dir++;
}
break;
}
**5.**然后把结果表示出来
for(i=0;i<n;i++){
for(j=0;j<n;j++){
printf("%3d",arr[i][j]);
}
printf("\n");
}
**6.**写该程序的关键为利用switch函数区分情况区分即可。
结果图文为