乱乱的分析过程

感觉我这个比较好理解,基本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;
}