题解 | #蛇形矩阵#
蛇形矩阵
http://www.nowcoder.com/practice/649b210ef44446e3b1cd1be6fa4cab5e
#include <stdio.h>
void snake(int _n)
{
int *head = (int*)calloc(_n, sizeof(int));
head[0] = 1;
for (int i = 1; i < _n; i++) {
head[i] = head[i-1] + i;
}
for (int i = 0; i < _n; i++) { // column
int bgn = head[i];
printf("%d ", bgn);
for (int j = i + 2; j <= _n; j++) {
bgn += j;
printf("%d ", bgn);
}
printf("\n");
}
free(head);
}
int main()
{
int input = 0;
while (EOF != scanf("%d", &input)) {
snake(input);
}
return 0;
} 蛇形矩阵是由1开始的自然数依次排列成的一个矩阵上三角形。
例如,当输入5时,应该输出的三角形为:
1 3 6 10 15
2 5 9 14
4 8 13
7 12
11
请注意本题含有多组样例输入。
输入描述:
输入正整数N(N不大于100)
输出描述:
输出一个N行的蛇形矩阵。
就花点时间找规律呗……