ZSTUOJ平台刷题⑤:Problem G.--深入浅出学算法023-旋转数阵
Problem G: 深入浅出学算法023-旋转数阵
Time Limit: 1 Sec Memory Limit: 64 MBSubmit: 4794 Solved: 955
Description
把1到n2的正整数从左上角开始由外层至中心按照顺时针方向螺旋排列
Input
输入整数n (1 <= n <= 10)
Output
按示例输出矩阵
Sample Input
3 4
Sample Output
1 2 3 8 9 4 7 6 5 1 2 3 4 12 13 14 5 11 16 15 6 10 9 8 7
代码如下:
#include<bits/stdc++.h> using namespace std; int main(){ int a[11][11]; int n; while(~scanf("%d",&n)){ memset(a,0,sizeof(a)); int x,y,tot=0; a[x=0][y=0]=tot=1; while(tot<n*n){ while(y+1<n&&!a[x][y+1]) a[x][++y]=++tot; while(x+1<n&&!a[x+1][y]) a[++x][y]=++tot; while(y-1>=0&&!a[x][y-1]) a[x][--y]=++tot; while(x-1>=0&&!a[x-1][y]) a[--x][y]=++tot; } if(n<=3){ for(x=0;x<n;x++){ for(y=0;y<n;y++){ if(y==0) printf("%d",a[x][y]); else printf("%2d",a[x][y]); } printf("\n"); } } else if(n==10){ for(x=0;x<n;x++){ for(y=0;y<n;y++){ if(y==0) printf("%3d",a[x][y]); else printf("%4d",a[x][y]); } printf("\n"); } } else{ for(x=0;x<n;x++){ for(y=0;y<n;y++){ if(y==0) printf("%2d",a[x][y]); else printf("%3d",a[x][y]); } printf("\n"); } } } return 0; }