一【题目难度】
- 乙级
二【题目编号】
- 1052 卖个萌 (20 分)
三【题目描述】
- 萌萌哒表情符号通常由“手”、“眼”、“口”三个主要部分组成。简单起见,我们假设一个表情符号是按下列格式输出的:
[左手]([左眼][口][右眼])[右手]
- 现给出可选用的符号集合,请你按用户的要求输出表情。
四【题目示例】
-
输入格式:
输入首先在前三行顺序对应给出手、眼、口的可选符号集。每个符号括在一对方括号 []内。题目保证每个集合都至少有一个符号,并不超过 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? @/@
五【解题思路】
- 这个题最重要的是首先理解题意:大意就给的数据前三行分别是手、眼、口([]中的字符)的可以组成表情的字符,然后需要组成k个字符,说白了就是需要把前三行分别存储在手、眼、口的各自数组中,然后按照最后几行的下标依次输出即可,如果下标不对,则输出Are you kidding me? @\/@。下面说一说题目难点和坑点:
① 难点:这个题的难点主要是字符的输入问题,我第一次是直接输入然后用 i f … e l s e if…else if…else去匹配存储,这样不知道为什么输出没有结果,后来使用正则匹配%[^]]
,表示]
之前的全部匹配到,这样就能把每个可选字符存储到各自的数组中了,后面就好办了,用a[3]数组记录手、眼、口的各自可选字符的个数,用b[5]数组记录每次要输出的手、眼、口的各自数组索引下标,判断一下然后输出即可
② 坑点:注意要使用\
将\
转义,否则会出错;另外颜文字的可选字符长度不一定为1,所以数组空间开辟大一些
六【最终得分】
- 20分
七【代码实现】
#include<stdio.h>
int main()
{
int a[3] = {0},b[5] = {0},k;
char hand[10][5] = {0},eye[10][5] = {0},mouth[10][5] = {0},temp;
while((temp = getchar()) != '\n')
{
if(temp == '[')
{
scanf("%[^]]",hand[a[0]++]);
}
}
while((temp = getchar()) != '\n')
{
if(temp == '[')
{
scanf("%[^]]",eye[a[1]++]);
}
}
while((temp = getchar()) != '\n')
{
if(temp == '[')
{
scanf("%[^]]",mouth[a[2]++]);
}
}
scanf("%d",&k);
for(int i = 0;i<k;i++)
{
scanf("%d %d %d %d %d",&b[0],&b[1],&b[2],&b[3],&b[4]);
if(b[0] < 1 || b[1] < 1 || b[2] < 1 || b[3] < 1 || b[4] < 1)
{
printf("Are you kidding me? @\\/@\n");
}
else if(b[0] > a[0] || b[1] > a[1] || b[2] > a[2] || b[3] > a[1] || b[4] > a[0])
{
printf("Are you kidding me? @\\/@\n");
}
else
{
printf("%s(%s%s%s)%s\n",hand[b[0] - 1],eye[b[1] - 1],mouth[b[2] - 1],eye[b[3] - 1],hand[b[4] - 1]);
}
}
return 0;
}