PAT乙级1109 擅长C
题目:
当你被面试官要求用 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.
分析:
1、字母用string[26][7]存储。
2、查到不是大写字母的部分,或者到末尾了,就开始一行一行打印,在这个过程中需要记录字母顺序。
3、比较坑的地方:
要打印的字符串可能有空格,因此需要ignore掉换行符,再getline;
两个单词中间可能有不止一个非大写字母的字符;
可能是单个大写字母结尾;
用例: HELLO~~ WORLD!A
代码:
#include<iostream> #include<string> using namespace std; int main() { string english[26][7]; for(int i = 0; i < 26; i++) { for(int j = 0; j < 7; j++) { cin >> english[i][j]; } } int seq[10]; int cnt = 0; cin.ignore(10, '\n'); string s; getline(cin, s); int begin, end; //截取掉开头和结尾不是大写字母的部分 for(int i = 0; i < s.length(); i++) { if(s[i] >= 'A' && s[i] <= 'Z') { begin = i; break; } } for(int i = s.length() - 1; i >=0 ; i--) { if(s[i] >= 'A' && s[i] <= 'Z') { end = i; break; } } s = s.substr(begin, end - begin + 1); bool wait = false; for(int i = 0; i < s.length(); i++) { if(s[i] < 'A' || s[i] > 'Z' || i == s.length() - 1) { if(i == s.length() - 1) //如果以大写字母结尾 { int idx = s[i] - 'A'; seq[cnt] = idx; cnt++; wait = true; } if(wait) //处理单词间不止一个的非大写字母字符 { for(int j = 0; j < 7; j++) { for(int k = 0; k < cnt; k++) { cout << english[seq[k]][j]; if(k == cnt - 1 && j != 6) cout << endl; else if(k != cnt - 1) cout << " "; } } if(i != s.length() - 1) { cout << endl; cout << endl; cnt = 0; wait = false; } } } else { wait = true; int idx = s[i] - 'A'; seq[cnt] = idx; cnt++; } } return 0; }#刷题记录#
PAT乙级 文章被收录于专栏
PAT乙级(Basic)刷题记录