作者在 2011-08-26 21:06:35 发布以下内容
从键盘输入一个整数(1~20)
则以该数字为矩阵的大小,把1,2,3…n*n 的数字按照顺时针螺旋的形式填入其中。例如:
输入数字2,则程序输出:
1 2
4 3
输入数字3,则程序输出:
1 2 3
8 9 4
7 6 5
输入数字4, 则程序输出:
1 2 3 4
12 13 14 5
11 16 15 6
10 9 8 7
则以该数字为矩阵的大小,把1,2,3…n*n 的数字按照顺时针螺旋的形式填入其中。例如:
输入数字2,则程序输出:
1 2
4 3
输入数字3,则程序输出:
1 2 3
8 9 4
7 6 5
输入数字4, 则程序输出:
1 2 3 4
12 13 14 5
11 16 15 6
10 9 8 7
#include<stdio.h>
#define N 21
void main()
{
int i,j,k,n,sum=1,s;
int a[N][N]={0};
printf("Input n (n<=20):");
scanf("%d",&n);
s=n*n;
for(i=1;i<=n;i++)
{
for(j=i,k=i;k<=n-i+1;k++)
{
a[j][k]=sum;
sum++;
if(sum>s)
break;
}
for(j=i+1,k=n-i+1;j<=n-i+1;j++)
{
a[j][k]=sum;
sum++;
if(sum>s)
break;
}
for(j=n-i+1,k=n-i;k>=i;k--)
{
a[j][k]=sum;
sum++;
if(sum>s)
break;
}
for(j=n-i,k=i;j>=i+1;j--)
{
a[j][k]=sum;
sum++;
if(sum>s)
break;
}
}
for(j=1;j<=n;j++)
{
for(k=1;k<=n;k++)
printf("%4d",a[j][k]);
printf("\n");
}
}
#define N 21
void main()
{
int i,j,k,n,sum=1,s;
int a[N][N]={0};
printf("Input n (n<=20):");
scanf("%d",&n);
s=n*n;
for(i=1;i<=n;i++)
{
for(j=i,k=i;k<=n-i+1;k++)
{
a[j][k]=sum;
sum++;
if(sum>s)
break;
}
for(j=i+1,k=n-i+1;j<=n-i+1;j++)
{
a[j][k]=sum;
sum++;
if(sum>s)
break;
}
for(j=n-i+1,k=n-i;k>=i;k--)
{
a[j][k]=sum;
sum++;
if(sum>s)
break;
}
for(j=n-i,k=i;j>=i+1;j--)
{
a[j][k]=sum;
sum++;
if(sum>s)
break;
}
}
for(j=1;j<=n;j++)
{
for(k=1;k<=n;k++)
printf("%4d",a[j][k]);
printf("\n");
}
}