乱乱的分析过程
感觉我这个比较好理解,基本30行解决问题
经过画图发现都是反斜线输入,这时候就联想起i+j = n-1的条件,再发现以i+j = n - 1为分界线,前面的斜线分别是i + j = n-2,i+j = n-3.....后面的分别是i+j = n,i+j = n+1...以此类推,让count= i+j,count从0开始再进行累加,直到2 * n-2结束。
此时就可以打印出
经过观察发现从下往上打的都是i+j是偶数的,所以再加上一个判断条件就可以啦~ 还是很好理解的吧
#define _CRT_SECURE_NO_WARNINGS 1 #include <stdio.h> int main() { int n; scanf("%d", &n); int arr[20][20] = { 0 }; int i = 0, j = 0; int count = 0; int sum = 1; while (count <= 2 * n - 2) { for (i = 0; i < n; i++) { for (j = 0; j < n; j++) { if (i + j == count) { if (count % 2 == 0) { arr[j][i] = sum++; } else { arr[i][j] = sum++; } } } } count++; } for (i = 0; i < n; i++) { for (j = 0; j < n; j++) { printf("%d ", arr[i][j]); } printf("\n"); } return 0; }