螺旋数组

基本思路

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

代码实现

#include
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 {
a[i][j]=count++;
for(j++;j a[i][j]=count++;
for(i++,j–;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 {
for( j=0; j printf("%4d “,a[i][j]);
printf(”\n");
}
return 0;
}
本人为初学小白,知识储备有待提高,第一次写博客,有什么问题还请多指教

你可能感兴趣的:(算法题)