1052. 卖个萌 (20) PAT乙级真题
来源:互联网 发布:方正字体识别软件 编辑:程序博客网 时间:2024/05/22 17:25
1052. 卖个萌 (20)
萌萌哒表情符号通常由“手”、“眼”、“口”三个主要部分组成。简单起见,我们假设一个表情符号是按下列格式输出的:
[左手]([左眼][口][右眼])[右手]
现给出可选用的符号集合,请你按用户的要求输出表情。
输入格式:
输入首先在前三行顺序对应给出手、眼、口的可选符号集。每个符号括在一对方括号[]内。题目保证每个集合都至少有一个符号,并不超过10个符号;每个符号包含1到4个非空字符。
之后一行给出一个正整数K,为用户请求的个数。随后K行,每行给出一个用户的符号选择,顺序为左手、左眼、口、右眼、右手——这里只给出符号在相应集合中的序号(从1开始),数字间以空格分隔。
输出格式:
对每个用户请求,在一行中输出生成的表情。若用户选择的序号不存在,则输出“Are you kidding me? @\/@”。
输入样例:[╮][╭][o][~\][/~] [<][>] [╯][╰][^][-][=][>][<][@][⊙][Д][▽][_][ε][^] ...41 1 2 2 26 8 1 5 53 3 4 3 32 10 3 9 3
输出样例:╮(╯▽╰)╭<(@Д=)/~o(^ε^)oAre you kidding me? @\/@
表示一开始看到那么多奇形怪状的图案真的吓到了好吗。我是用一个三维数组存放的表情。我下面先讲讲这题里面我踩过的坑吧:一、两个表情之间不知道到底是什么(“[”和“]”之间可能有不止一个空格或者其它符号)。二、输入的数字可能是负数!!!,一开始只考虑过大的数字导致没得输出,然而还是一直提示段错误,也就是数组越界,一开始一直扩大数组大小,结果还是错,真没想到会有负数这么坑的数据。我好像就没碰到其它坑了,下面是我的代码:#include<stdio.h>int main(void){ char c[5][100][100]={' ',' ',' '}; //一开始一直扩大后来就没减回去了 int hand=0,eye=0,mouth=0; int i,j,k; int f; int a[5]; do { j=0; while(c[0][hand][j]!='[' && c[0][hand][j]!='\n') { scanf("%c",&c[0][hand][j]); } if (c[0][hand][j]!='[') break; //这里是这行输入结束后直接退出循环,下同。 do { scanf("%c",&c[0][hand][j]); }while(c[0][hand][j++]!=']'); c[0][hand][--j]='\0'; scanf("%c",&c[0][++hand][0]); }while(c[0][hand][0]!='\n'); do { j=0; while(c[1][eye][j]!='[' && c[1][eye][j]!='\n') { scanf("%c",&c[1][eye][j]); } if (c[1][eye][j]!='[') break; do { scanf("%c",&c[1][eye][j]); }while(c[1][eye][j++]!=']'); c[1][eye][--j]='\0'; scanf("%c",&c[1][++eye][0]); }while(c[1][eye][0]!='\n'); do { j=0; while(c[2][mouth][j]!='[' && c[2][mouth][j]!='\n') { scanf("%c",&c[2][mouth][j]); } if (c[2][mouth][j]!='[') break; do { scanf("%c",&c[2][mouth][j]); }while(c[2][mouth][j++]!=']'); c[2][mouth][--j]='\0'; scanf("%c",&c[2][++mouth][0]); }while(c[2][mouth][0]!='\n'); scanf("%d",&k); for (i=0;i<k;i++) { scanf("%d %d %d %d %d",&a[0],&a[1],&a[2],&a[3],&a[4]); if (a[0]>hand || a[1]>eye || a[2]>mouth || a[3]>eye || a[4]>hand || a[0]<1 || a[1]<1 || a[2]<1 || a[3]<1 || a[4]<1) { printf("Are you kidding me? @\\/@"); } else { printf("%s(%s%s%s)%s",c[0][a[0]-1],c[1][a[1]-1],c[2][a[2]-1],c[1][a[3]-1],c[0][a[4]-1]); } if (i<k-1) printf("\n"); } return 0;}
阅读全文
0 0
- 1052. 卖个萌 (20)-PAT乙级真题
- 1052. 卖个萌 (20) PAT乙级真题
- PAT乙级真题
- 1028. 人口普查(20)-PAT乙级真题
- 1004. 成绩排名 (20)-PAT乙级真题
- 1057. 数零壹(20)-PAT乙级真题
- 1058. 选择题(20)-PAT乙级真题
- 1004. 成绩排名 (20) PAT乙级真题
- pat乙级真题 1068. 万绿丛中一点红(20)
- 1028. 人口普查(20) PAT乙级真题
- 1057. 数零壹(20) PAT乙级真题
- 1058. 选择题(20) PAT乙级真题
- 1068. 万绿丛中一点红(20) PAT乙级真题
- 1052. 卖个萌 (20) PAT乙级
- PAT 乙级 1052. 卖个萌 (20)
- PAT乙级 1052. 卖个萌 (20)
- [PAT乙级]1052. 卖个萌 (20)
- PAT乙级1052. 卖个萌 (20)
- 搜索引擎研究之一:选型
- Oracle修改数据库用户名
- 关于ie8的滤镜
- 小小的IP,大大的耦合
- 524. Longest Word in Dictionary through Deleting
- 1052. 卖个萌 (20) PAT乙级真题
- ANR 分析解决
- Spring MVC的自动转换功能 HttpMessageConverter
- JAVA调用ImageCapOnWeb控件实现拍照功能
- angular API
- 最小树形图
- 如何一次终止同一名字的多个进程
- 分布式缓存Redis之配置文件redis.conf详解
- 设计模式(十四)——备忘录模式