【PAT乙级】1109 擅长C (20 分) C语言实现

当你被面试官要求用 C 写一个“Hello World”时,有本事像下图显示的那样写一个出来吗?
HELLO WORLD

输入格式:

输入首先给出 26 个英文大写字母 A-Z,每个字母用一个 7×5 的、由 C 和 . 组成的矩阵构成。最后在一行中给出一个句子,以回车结束。句子是由若干个单词(每个包含不超过 10 个连续的大写英文字母)组成的,单词间以任何非大写英文字母分隔。

题目保证至少给出一个单词。

输出格式:

对每个单词,将其每个字母用矩阵形式在一行中输出,字母间有一列空格分隔。单词的首尾不得有多余空格。

相邻的两个单词间必须有一空行分隔。输出的首尾不得有多余空行。

输入样例:

..C..
.C.C.
C...C
CCCCC
C...C
C...C
C...C
CCCC.
C...C
C...C
CCCC.
C...C
C...C
CCCC.
.CCC.
C...C
C....
C....
C....
C...C
.CCC.
CCCC.
C...C
C...C
C...C
C...C
C...C
CCCC.
CCCCC
C....
C....
CCCC.
C....
C....
CCCCC
CCCCC
C....
C....
CCCC.
C....
C....
C....
CCCC.
C...C
C....
C.CCC
C...C
C...C
CCCC.
C...C
C...C
C...C
CCCCC
C...C
C...C
C...C
CCCCC
..C..
..C..
..C..
..C..
..C..
CCCCC
CCCCC
....C
....C
....C
....C
C...C
.CCC.
C...C
C..C.
C.C..
CC...
C.C..
C..C.
C...C
C....
C....
C....
C....
C....
C....
CCCCC
C...C
C...C
CC.CC
C.C.C
C...C
C...C
C...C
C...C
C...C
CC..C
C.C.C
C..CC
C...C
C...C
.CCC.
C...C
C...C
C...C
C...C
C...C
.CCC.
CCCC.
C...C
C...C
CCCC.
C....
C....
C....
.CCC.
C...C
C...C
C...C
C.C.C
C..CC
.CCC.
CCCC.
C...C
CCCC.
CC...
C.C..
C..C.
C...C
.CCC.
C...C
C....
.CCC.
....C
C...C
.CCC.
CCCCC
..C..
..C..
..C..
..C..
..C..
..C..
C...C
C...C
C...C
C...C
C...C
C...C
.CCC.
C...C
C...C
C...C
C...C
C...C
.C.C.
..C..
C...C
C...C
C...C
C.C.C
CC.CC
C...C
C...C
C...C
C...C
.C.C.
..C..
.C.C.
C...C
C...C
C...C
C...C
.C.C.
..C..
..C..
..C..
..C..
CCCCC
....C
...C.
..C..
.C...
C....
CCCCC
HELLO~WORLD!

输出样例:

C...C CCCCC C.... C.... .CCC.
C...C C.... C.... C.... C...C
C...C C.... C.... C.... C...C
CCCCC CCCC. C.... C.... C...C
C...C C.... C.... C.... C...C
C...C C.... C.... C.... C...C
C...C CCCCC CCCCC CCCCC .CCC.

C...C .CCC. CCCC. C.... CCCC.
C...C C...C C...C C.... C...C
C...C C...C CCCC. C.... C...C
C.C.C C...C CC... C.... C...C
CC.CC C...C C.C.. C.... C...C
C...C C...C C..C. C.... C...C
C...C .CCC. C...C CCCCC CCCC.

华丽的分割线

解题思路:

  1. 先用二维数组将 26 个英文大写字母 A-Z 的矩阵保存下来
  2. 由于给出的句子由若干个单词组成,而句子长度又不确定,因此只能边输入边输出
  3. 单词间以任何非大写英文字母分隔,因此可能包括了空格符号,因此不能使用 %s 去接收整个字符串,因此只能一个一个字符去接收。(scanf 中,空格符或换行符代表一个句子的结束)
  4. 单词矩阵的打印,使用两层 for 循环:因为行数确定为 7 行,因外层次数为 7 次;内层循环为打印单词的次数;一行矩阵的打印,直接使用 %s 输出一行字符串

测试的句子用例:

abcHELLOdef WORLD!asd
   def WORLD
abcHELLOdef WORLD
HELLO WORLD!

代码实现:

#include <stdio.h>
#include <string.h>

// 判断字符是否是大写字母
int isUpper(char ch);
// 打印一个单词
void printWordMatrix(char *w, int len, char Matrix[][6]);

int main() {
    int x = 26 * 7;
    int y = 6;
    // 获取输入并分别放置到两个数组 英文矩阵数组 && 句子数组
    char matrix[x][y];
    for (int i = 0; i < x + 1; i++) {
        if (i == x) {
            // 将英文矩阵数组最后的空格符吸收
            getchar();

            // 输入一个完整的单词后,就输出矩阵
            char ch;
            char result[10] = {0};
            int index = 0, newline = 0;
            while((ch = getchar()) != '\n') {
                if (!isUpper(ch)) {
                    result[index] = '\0';
                    int len = strlen(result);
                    if (len != 0) {
                        // 输出额外的空行,首尾不得有多余空行
                        if (newline != 0) {
                            printf("\n");
                        }
                        printWordMatrix(result, len, matrix);
                        newline += 1;
                    }

                    // 重置单词数组
                    index = 0;
                    result[index] = '\0';
                } else {
                    result[index++] = ch;
                }
            }

            // 解决输入案例的句子最后一个字符为 大写英文字母 的情况
            if (strlen(result) != 0) {
                if (newline != 0) {
                    printf("\n");
                }
                printWordMatrix(result, strlen(result), matrix);
            }
        } else {
            // 英文字符矩阵数组
            scanf("%s", matrix[i]);
        }
    }

    return 0;
}

// 判断字符是否是大写字母
int isUpper(char ch) {
    // if ('A' <= ch && ch <= 'Z') {}

    int num = ch - 'A';
    if (0 <= num && num <= 25) {
        return 1;
    } else {
        return 0;
    }
}

// 打印一个单词
void printWordMatrix(char *w, int len, char Matrix[][6]) {
    // 打印行数为 7 次,因此字符矩阵为 7 * 5
    for (int i = 0; i < 7; i++) {
        // 打印单词的长度
        for (int j = 0; j < len; j++) {
            int t = w[j] - 'A';
            // 英文矩阵数组的行下标,输出一整行字符串
            int index = t * 7 + i;
            printf("%s", Matrix[index]);

            if (j != len - 1) {
                printf(" ");
            }
        }
        printf("\n");
    }
}
posted @ 2022-05-26 09:29  夏夜星空晚风  阅读(135)  评论(0编辑  收藏  举报