螺旋数组

  • Post author:
  • Post category:其他




基本思路


螺旋矩阵是指一个呈螺旋状的矩阵,它的数字由第一行开始到右边不断变大,向下变大,向左变大,向上变大,如此循环。利用jC实现的螺旋矩阵,当输入N之后,会自动打印出螺旋矩阵。

在这里插入图片描述



代码实现

#include <stdio.h>

int main()

{


int a[23][23],num,count,i,j,k,kend,lend;

printf(“输入[1-23]其中一个数: “);

scanf(”%d”,&num);

kend=num/2;/

螺旋数组是转圈圈执行的,转一圈结束,上下左右各一行都被赋值

/

lend=num;

count=1;

for( i=0,j=0,k=0; k<kend; k++ )

{


a[i][j]=count++;

for(j++;j<lend;j++)

a[i][j]=count++;

for(i++,j–;i<lend;i++)/

上一个循环结束j被多赋1值,此循环开始需要减去j被多赋的值

/

a[i][j]=count++;

for(i–,j–;j>=k;j–)/

同理i,j也是上面的原理啦

/

a[i][j]=count++;

for(i–,j++;i>k;i–)

a[i][j]=count++;

i++;j++;lend–;

}

if(num%2 != 0) a[i][j]=count;

for( i=0; i<num; i++ )

{


for( j=0; j<num; j++ )

printf(“%4d “,a[i][j]);

printf(”\n”);

}

return 0;

}

本人为初学小白,知识储备有待提高,第一次写博客,有什么问题还请多指教



版权声明:本文为Czx_1225原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。