[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? @\/@')

你可能感兴趣的:([PAT]1052 卖个萌 (20分)(Python)(编码问题无解))