当你被面试官要求用 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.
测试点1234找了一个小时 醉了,我的测试点12是因为不能用cin读取字符串,cin遇到空格会截断(题目中可能会有空格输入),测试点34是程序逻辑问题。当输入最后一个为大写字母时,我的容器类内没有放入最后一个单词。
我的代码如下
#include<vector>
#include<string>
#include <iostream>
#include<vector>
using namespace std;
int main()
{
vector<pair<string, int>>vec;
string str1;
for (int i = 0; i < 26 * 7; i++)
{
string str;
cin >> str;
vec.push_back(make_pair(str,i));
}
vector<string>vecstring;
cin.ignore();
getline(cin,str1);
string temp;
int count = 0;
for (int i = 0; i < str1.size(); i++)
{
if (str1[i] < 'A' || str1[i]>'Z')
{
if(temp.size()!=0)
vecstring.push_back(temp);
temp = "";
}
else
{
count++;
temp += str1[i];
}
}
if (str1[str1.size()-1] >= 'A' && str1[str1.size()-1] <= 'Z')
{
vecstring.push_back(temp);
}
if (count == 0)
{
return 0;
}
for (int k = 0; k < vecstring.size(); k++)
{
for (int j = 0; j < 7; j++)
{
string temp1 = vecstring[k];
for (int i = 0; i < temp1.size(); i++)
{
int temp = (temp1[i] - 65) * 7 + j;
if (i != temp1.size() - 1)
{
cout << vec[temp].first<<" ";
}
else
cout << vec[temp].first;
}
if(j!=6)
cout << endl;
}
if (k != vecstring.size() - 1)
{
cout << endl;
cout << endl;
}
else
{
cout << endl;
}
}
}