

这一题思路上没有什么复杂的,按题意模拟,即可
关建在于格式,题目上说不同的单词中间有其他非A到Z的字符隔开,但可能只有一个单词,那么结尾就可能没有其他字符,可能在两个单词之间其他字符可能有多个,甚至这里的其他字符包括空格!!!
因此在输入一串单词的时候我们应该用getchar来吞掉输入A到Z对应的的矩形输入后的回车,然后再用getline(cin,s)来读取字符串(为啥用getline因为有空格)
完整代码如下:
cpp
#define _CRT_SECURE_NO_WARNINGS 1
#include<iostream>
#include <unordered_map>
#include <vector>
#include <cstring>
#include <cstdio>
#include <string.h>
#include <string>
using namespace std;
unordered_map<char, vector<vector<char>> > mp;
int main()
{
for (int i = 0; i < 26; i++)
{
vector<vector<char>> t(7);
for (int j = 0; j < 7; j++)
{
for (int k = 0; k < 5; k++)
{
char x;
cin >> x;
t[j].push_back(x);
}
}
mp[char('A' + i)] = t;
}
getchar();
string s;
getline(cin, s);
vector<string> x;
int last = -1;
string tt="";
for (int i = 0; i < s.size(); i++)
{
if (s[i] >= 'A' && s[i] <= 'Z')
{
//符合条件
tt += s[i];
}
else
{
if(tt.size()!=0)
x.push_back(tt);
tt = "";
}
}
if (tt.size() != 0)
{
x.push_back(tt);
}
//这样就把每一个单词给分割了
for (int p = 0; p < x.size(); p++)
{
for (int i = 0; i < 7; i++)
{
string temp = x[p];
for (int j = 0; j < temp.size(); j++)
{
vector<vector<char>> ans = mp[temp[j]];
for (int k = 0; k < ans[i].size(); k++)
{
cout << ans[i][k];
}
if(j!=temp.size()-1)
cout << " ";
}
cout << endl;
}
if (p != x.size() - 1)
{
cout << endl;
}
}
return 0;
}
注意PAT的输出末尾不能有空格