1109 擅长C (20 分)
当你被面试官要求用 C 写一个“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.
解题思路: 这有啥好说的。。。模拟暴力,但是这么说又对不起我调了一个多小时的代码,这题非常魔鬼,建议大家先想好用什么数据存储,我使用一个二维的string,不要用三维数组,否则可能会很麻烦,答案存储就用一个一维的string,代码最难的地方是在于给string加空格和换行插入字符,代码虽然简短,但是还是希望大家耐下心自己调试,对提高码力还是非常有帮助的。
#include<bits/stdc++.h>
using namespace std;
const int N = 27;
string a[N][10],res[5010],s;
int main()
{
for (int i = 0 ; i < 26 ; i ++ ){
for (int j = 0 ;j < 7 ;j ++ ){
getline(cin, a[i][j]);
}
}
getline(cin,s);
int x = 0,num = 0,flag = 0;
for (int i = 0 ; i < s.size() ; i ++ ){
if(s[i] >= 'A' && s[i] <= 'Z'){
for (int j = 0 ;j < 7; j ++ ){
res[x] += a[s[i] - 'A'][j];
if(s[i + 1] >= 'A' && s[i + 1] <= 'Z') res[x] += ' ';
x ++;
}
flag = 1;
}
else if(flag){num += 7;flag = 0;}
x = x % 7 + num;
}
for (int i = 0 ;res[i].size() != 0;i ++ ){
if(i % 7 == 0 && i != 0) cout<<endl;
printf("%s\n",res[i].c_str());
}
return 0;
}
就说这么多了,有问题的话评论区提问我。