• 1164 Good in C – PAT甲级真题


    When your interviewer asks you to write “Hello World” using C, can you do as the following figure shows?

    Input Specification:

    Each input file contains one test case. For each case, the first part gives the 26 capital English letters A-Z, each in a 7×5 matrix of C‘s and .‘s. Then a sentence is given in a line, ended by a return. The sentence is formed by several words (no more than 10 continuous capital English letters each), and the words are separated by any characters other than capital English letters.

    It is guaranteed that there is at least one word given.

    Output Specification:

    For each word, print the matrix form of each of its letters in a line, and the letters must be separated by exactly one column of space. There must be no extra space at the beginning or the end of the word.

    Between two adjacent words, there must be a single empty line to separate them. There must be no extra line at the beginning or the end of the output.

    Sample Input:

    1. ..C..
    2. .C.C.
    3. C...C
    4. CCCCC
    5. C...C
    6. C...C
    7. C...C
    8. CCCC.
    9. C...C
    10. C...C
    11. CCCC.
    12. C...C
    13. C...C
    14. CCCC.
    15. .CCC.
    16. C...C
    17. C....
    18. C....
    19. C....
    20. C...C
    21. .CCC.
    22. CCCC.
    23. C...C
    24. C...C
    25. C...C
    26. C...C
    27. C...C
    28. CCCC.
    29. CCCCC
    30. C....
    31. C....
    32. CCCC.
    33. C....
    34. C....
    35. CCCCC
    36. CCCCC
    37. C....
    38. C....
    39. CCCC.
    40. C....
    41. C....
    42. C....
    43. CCCC.
    44. C...C
    45. C....
    46. C.CCC
    47. C...C
    48. C...C
    49. CCCC.
    50. C...C
    51. C...C
    52. C...C
    53. CCCCC
    54. C...C
    55. C...C
    56. C...C
    57. CCCCC
    58. ..C..
    59. ..C..
    60. ..C..
    61. ..C..
    62. ..C..
    63. CCCCC
    64. CCCCC
    65. ....C
    66. ....C
    67. ....C
    68. ....C
    69. C...C
    70. .CCC.
    71. C...C
    72. C..C.
    73. C.C..
    74. CC...
    75. C.C..
    76. C..C.
    77. C...C
    78. C....
    79. C....
    80. C....
    81. C....
    82. C....
    83. C....
    84. CCCCC
    85. C...C
    86. C...C
    87. CC.CC
    88. C.C.C
    89. C...C
    90. C...C
    91. C...C
    92. C...C
    93. C...C
    94. CC..C
    95. C.C.C
    96. C..CC
    97. C...C
    98. C...C
    99. .CCC.
    100. C...C
    101. C...C
    102. C...C
    103. C...C
    104. C...C
    105. .CCC.
    106. CCCC.
    107. C...C
    108. C...C
    109. CCCC.
    110. C....
    111. C....
    112. C....
    113. .CCC.
    114. C...C
    115. C...C
    116. C...C
    117. C.C.C
    118. C..CC
    119. .CCC.
    120. CCCC.
    121. C...C
    122. CCCC.
    123. CC...
    124. C.C..
    125. C..C.
    126. C...C
    127. .CCC.
    128. C...C
    129. C....
    130. .CCC.
    131. ....C
    132. C...C
    133. .CCC.
    134. CCCCC
    135. ..C..
    136. ..C..
    137. ..C..
    138. ..C..
    139. ..C..
    140. ..C..
    141. C...C
    142. C...C
    143. C...C
    144. C...C
    145. C...C
    146. C...C
    147. .CCC.
    148. C...C
    149. C...C
    150. C...C
    151. C...C
    152. C...C
    153. .C.C.
    154. ..C..
    155. C...C
    156. C...C
    157. C...C
    158. C.C.C
    159. CC.CC
    160. C...C
    161. C...C
    162. C...C
    163. C...C
    164. .C.C.
    165. ..C..
    166. .C.C.
    167. C...C
    168. C...C
    169. C...C
    170. C...C
    171. .C.C.
    172. ..C..
    173. ..C..
    174. ..C..
    175. ..C..
    176. CCCCC
    177. ....C
    178. ...C.
    179. ..C..
    180. .C...
    181. C....
    182. CCCCC
    183. HELLO~WORLD!

    Sample Output:

    1. C...C CCCCC C.... C.... .CCC.
    2. C...C C.... C.... C.... C...C
    3. C...C C.... C.... C.... C...C
    4. CCCCC CCCC. C.... C.... C...C
    5. C...C C.... C.... C.... C...C
    6. C...C C.... C.... C.... C...C
    7. C...C CCCCC CCCCC CCCCC .CCC.
    8. C...C .CCC. CCCC. C.... CCCC.
    9. C...C C...C C...C C.... C...C
    10. C...C C...C CCCC. C.... C...C
    11. C.C.C C...C CC... C.... C...C
    12. CC.CC C...C C.C.. C.... C...C
    13. C...C C...C C..C. C.... C...C
    14. C...C .CCC. C...C CCCCC CCCC.

    题目大意:输入首先给出26个英文大写字母A-Z,每个字母用7×5的、由C和.组成的矩阵构成。最后在一行中给出一个句子,以回车结束。句子是由若干个单词(每个包含不超过10个连续的大写英文字母)组成的,单词间以任何非大写英文字母分隔。题目保证至少给出一个单词。输出要求:对于每个单词,将其中每个字母用矩阵形式在一行中输出,字母间有一列空格分隔。单词的首尾不得有多余空格。相邻的两个单词间必须有一空行分隔。输出的首尾不得有多余空行。

    分析:三维数组a中储存26个字母对应的图形矩阵,out中储存每行要输出的图形矩阵,同时初始化out所有元素为空格。字符串中可能存在乱七八糟的字符,所以用getline做句子的输入。句子的单词间以任何非大写字母分隔,用while循环遍历找到下标j为非大写字母所在下标,i为当前单词首下标,然后根据单词中每一个字母,将输出图形记录到out中,最后输出out数组~flag用来标记之前是否输出过一个单词,如果输出过,flag=1,则当再次需要输出单词之前需要先输出一个’\n’~

    1. #include
    2. using namespace std;
    3. char a[26][7][5], out[7][100];
    4. string s;
    5. int main() {
    6. for (int i = 0; i < 7; i++)
    7. for (int j = 0; j < 100; j++)
    8. out[i][j] = ' ';
    9. for (int i = 0; i < 26; i++)
    10. for (int j = 0; j < 7; j++)
    11. for (int k = 0; k < 5; k++)
    12. cin >> a[i][j][k];
    13. getchar();
    14. getline(cin, s);
    15. for (int i = 0, j, flag = 0; i < s.size(); i++) {
    16. j = i;
    17. while (j < s.size() && s[j] >= 'A' && s[j] <= 'Z') j++;
    18. if (i == j) continue;
    19. for (int k = i; k < j; k++)
    20. for (int l = 0; l < 7; l++)
    21. for (int m = 0; m < 5; m++)
    22. out[l][m + (k - i) * 6] = a[s[k] - 'A'][l][m];
    23. if (flag) cout << '\n';
    24. for (int k = 0; k < 7; k++) {
    25. flag = 1;
    26. for (int l = 0; l < 6 * (j - i) - 1; l++) cout << out[k][l];
    27. cout << '\n';
    28. }
    29. i = j;
    30. }
    31. return 0;
    32. }

  • 相关阅读:
    嵌入式:驱动开发 Day9
    聊一聊如何整合Microsoft.Extensions.DependencyInjection和Castle.Core(二)
    JDBC MySQL任意文件读取分析
    leetCode 214.最短回文串 + KMP
    听书项目总结
    [附源码]java毕业设计医院网上预约系统
    我作为前端开发者对低代码平台的理解和搭建流程(一)
    英语——分享篇——每日200词——2601-2800
    好用的办公网优化工具OneDNS
    《opencv学习笔记》-- 查找并绘制轮廓
  • 原文地址:https://blog.csdn.net/liuchuo/article/details/126224402