这题让我们环形打印字母,很明显跟矩阵的下标有关,或者说是数组。
经观察我们可以得知,假设数字为n,那我们设置一个k值,k的取值范围为1~n。
每个正方形的宽度为2*n-k,这是我们扫描的范围,我们就让第k列,第k行,第2*n-k列,以及2*n-k行填入对应的数字就可以了。
我们打印的时候,就让A加上对应的数字,然后输出即可。
#include <cstdio> #include <iostream> int shape[100][100]; int main() { int n; scanf("%d", &n); for (int k = 1; k <= n;k++) { for (int i = k; i <= 2 * n - k;i++) { shape[i][k] = k - 1; shape[2 * n - k][i] = k - 1; shape[i][2 * n - k] = k - 1; shape[k][i] = k - 1; } } for (int i = 1; i <= 2 * n - 1; i++) { for (int j = 1; j <= 2 * n - 1;j++) { printf("%c", shape[i][j] + 'A'); } printf(" "); } system("pause"); return 0; }