擅长 $C$
题目描述
当你被面试官要求用 $C$ 写一个 Hello World
时,有本事像下图显示的那样写一个出来吗?
输入格式
输入首先给出 $26$ 个英文大写字母 $A \sim Z$,每个字母用一个 $7 \times 5$ 的、由 C
和 .
组成的矩阵构成。
最后在一行中给出一个句子,以回车结束。句子是由若干个单词(每个包含不超过 $10$ 个连续的大写英文字母)组成的,单词间以任何非大写英文字母分隔。
题目保证至少给出一个单词。
输出格式
对每个单词,将其每个字母用矩阵形式在一行中输出,字母间有一列空格分隔。单词的首尾不得有多余空格。
相邻的两个单词间必须有一空行分隔。输出的首尾不得有多余空行。
数据范围
最后一行句子的总长度范围 $[1,5000]$,
给出的单词数量范围 $[1,300]$。
输入样例:
..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.
... (省略约 160 行)
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.
正解:模拟
首先建一个字符数组把输入的 $26$ 的大写字母存起来。
然后一直用 getchar ()
输入要让我们输出的字符,如果遇到大写字母,就将它加入准备打印的单词字符串中;如果遇到不是大写字母的字符,就将准备打印的单词字符串打印出来。
如何打印一个单词呢?一行一行地打印出来就可以了,记得不要输出多余的空格或字符哦。
打印函数:
void print (char *str, int len) // str 表示打印的单词字符串,len 表示字符串的长度
{
if (!len) // 如果字符串长度为 0,直接返回
{
return ;
}
// 为了防止输出多余空行,我们采取在单词前面输出空行的形式。
if (flag) // 如果这个单词不是第一个单词
{
cout << endl << endl; // 输出两个空行
}
for (int i = 1; i <= w; i ++) // 一行一行地输出单词,一共 w 行(w = 7)
{
for (int j = 1; j <= len; j ++) // 遍历每个大写字母
{
for (int k = 1; k <= l; k ++) // 遍历大写字母的每一列(l = 5)
{
// a[i][j][k] 表示字母 i 的第 j 行第 k 列
cout << a[str[j]][i][k]; // 输出字母 str[j] 的第 i 行第 k 列
}
if (j < len) // 如果不是最后一个字母,输出空格
{
cout << ' '; // 不要输出多余空格
}
}
if (i < w) // 如果不是最后一行,输出换行
{
cout << endl; // 不要输出多余空行
}
}
flag = 1; // 下一个单词就不是第一个单词了
return ;
}
AC Code
#include <iostream>
#define l 5 // 字母的列数
#define w 7 // 字母的行数
#define N 15
#define P 131
#define L 10
#define W 10
using namespace std;
int t; // 当前单词长度
char c, p[N], a[P][W][L]; // c:用于输入;p:要打印的单词;a:存储输入的 26 个大写字母
bool flag = 0; // 是否不为第一个单词
void print (char *str, int len) // 打印函数(注释见上文)
{
if (!len)
{
return ;
}
if (flag)
{
cout << endl << endl;
}
for (int i = 1; i <= w; i ++)
{
for (int j = 1; j <= len; j ++)
{
for (int k = 1; k <= l; k ++)
{
cout << a[str[j]][i][k];
}
if (j < len)
{
cout << ' ';
}
}
if (i < w)
{
cout << endl;
}
}
flag = 1;
return ;
}
int main ()
{
for (int i = 'A'; i <= 'Z'; i ++) // 每一个大写字母
{
for (int j = 1; j <= w; j ++) // 每一行
{
cin >> a[i][j] + 1; // 输入这一行(输入一个字符串名 + 1 表示从这个字符串的下标 1 开始输入)
}
}
while (c = getchar ()) // 一直输入字符
{
if (c == EOF) // 如果到了文件末尾
{
break; // 退出
}
if (c < 'A' || c > 'Z') // 如果不是大写字母
{
print (p, t), t = 0; // 打印当前单词,单词字符串长度为 0
}
else // 如果是大写字母
{
p[++ t] = c; // 将单词字符串的末尾加上它
}
}
return 0;
}