题解 | 回型矩阵
回型矩阵
https://www.nowcoder.com/practice/36d5dfddc22c4f5b88a5b2a9de7db343
#include <stdio.h> int main() { int N,n,i=0,j=0,num=1;//n为圈数 scanf("%d",&N); int arr[20][20]; if(N%2!=0) { arr[N/2][N/2]=N*N; } for(n=0;n<N/2;n++) { for(j=n;j<N-n-1;j++)//向右 { arr[n][j]=num++; } for(i=n;i<N-n-1;i++)//向下 { arr[i][N-n-1]=num++; } for(j=N-n-1;j>=n+1;j--)//向左 { arr[N-n-1][j]=num++; } for(i=N-n-1;i>=n+1;i--) { arr[i][n]=num++; } } for(i=0;i<N;i++) { for(j=0;j<N;j++) { printf("%d ",arr[i][j]); } printf("\n"); } return 0; }