剥洋葱

这题让我们环形打印字母,很明显跟矩阵的下标有关,或者说是数组。
经观察我们可以得知,假设数字为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;
}
原文地址:https://www.cnblogs.com/xyqxyq/p/10450539.html