#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <string.h>
using namespace std;
int main() {
char arr[100][100] = { 0 };
int n;
while (scanf("%d",&n) !=EOF) {
int i = 0,j=0; // i代表行号
// 打印空格
for (i = 0; i <= n; ++i) {
//memset(arr, 0, 1000);
for (j = 0; j <= 2 * n - 2 * i; ++j) {
arr[i][j] = ' ';
}
// 打印前半部分字符
for (int k = 0; k <= i; ++k) {
arr[i][j] = '0' + k;
arr[i][j + 1] = ' ';
j = j + 2;
}
// 打印后半部分字符
for (int k = i - 1; k >= 0; --k) {
arr[i][j] = '0' + k;
arr[i][j + 1] = ' ';
j = j + 2;
}
}
// 打印下半部分
for (i = n + 1; i <= 2 * n; ++i) {
//memset(arr, 0, 1000); // 需要初始化,要不然会有遗留数据0
for (j = 0; j <= 2 * i - 2 * n; ++j) {
arr[i][j] = ' ';
}
// 打印前半部分字符
for (int k = 0; k <= 2 * n - i; ++k) { // 根据列发现每行最大字符为2*n-i
arr[i][j] = '0' + k;
arr[i][j + 1] = ' ';
j = j + 2;
}
// 打印后半部分字符
for (int k = 2 * n - i - 1; k >= 0; --k) {
arr[i][j] = '0' + k;
arr[i][j + 1] = ' ';
j = j + 2;
}
}
for (i = 0; i < 2 * n + 1; ++i) {
printf("%s\n", arr[i]);
}
}
return 0;
}
来源:王道计算机考研机试课程