[PAT]1052 卖个萌 (20分)(Python)(编码问题无解)

萌萌哒表情符号通常由“手”、“眼”、“口”三个主要部分组成。简单起见,我们假设一个表情符号是按下列格式输出的:
···
左手[右手]
···
现给出可选用的符号集合,请你按用户的要求输出表情。

输入格式:

输入首先在前三行顺序对应给出手、眼、口的可选符号集。每个符号括在一对方括号 []内。题目保证每个集合都至少有一个符号,并不超过 10 个符号;每个符号包含 1 到 4 个非空字符。

之后一行给出一个正整数 K,为用户请求的个数。随后 K 行,每行给出一个用户的符号选择,顺序为左手、左眼、口、右眼、右手——这里只给出符号在相应集合中的序号(从 1 开始),数字间以空格分隔。

输出格式:

对每个用户请求,在一行中输出生成的表情。若用户选择的序号不存在,则输出 Are you kidding me? @/@。

输入样例:

[╮][╭][o][~\][/~]  [<][>]
 [╯][╰][^][-][=][>][<][@][⊙]
[Д][▽][_][ε][^]  ...
4
1 1 2 2 2
6 8 1 5 5
3 3 4 3 3
2 10 3 9 3

输出样例:

╮(╯▽╰)╭
<(@Д=)/~
o(^ε^)o
Are you kidding me? @\/@

代码实现:

import re
shou = [x for x in re.split(r'[\]\s\[]',input()) if x]
yan = [x for x in re.split(r'[\]\s\[]',input()) if x]
kou = [x for x in re.split(r'[\]\s\[]',input()) if x]
ll = []
for i in range(int(input())):
    ll.append(list(map(lambda x:int(x)-1,input().split())))
for temp in ll:
    if temp[0] < len(shou) and temp[1] < len(yan) and temp[2] < len(kou) and temp[3] < len(yan) and temp[4] < len(shou):
        print(shou[temp[0]]+'('+yan[temp[1]]+kou[temp[2]]+yan[temp[3]]+')'+shou[temp[4]])
    else:
        print('Are you kidding me? @\/@')
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容