PAT Basic 1052. 卖个萌 (20)(C语言实现)
来源:互联网 发布:淘宝iphone官换机 价格 编辑:程序博客网 时间:2024/06/01 09:49
题目
萌萌哒表情符号通常由“手”、“眼”、“口”三个主要部分组成。简单起见,我们假设一个表情符号是按下列格式输出的:
[左手]([左眼][口][右眼])[右手]
现给出可选用的符号集合,请你按用户的要求输出表情。
输入格式:
输入首先在前三行顺序对应给出手、眼、口的可选符号集。每个符号括在一对方括号[]内。题目保证每个集合都至少有一个符号,并不超过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? @\/@
P.S.我终于知道简书的markdown怎么正常输出[^]了:*´∀`)´∀`)*´∀`)*´∀`)
[^...]
:不知道显示的什么鬼{FNXX==XXFN}[[]()^...]
:利用不占空间的空链接[^...]```[^...]```
:代码中使用三个backtick[^...]
思路
1 变长编码(Wiki: Variable-width encoding):
先了解一下这些颜表情符号是怎么能用8bit大小的字符输出的:如果用一字节一字节地读取,ASCII字符之外的字符会分解为多个字节,并且能够和单字节字符区分开,如拆分成多个的字节都大于127,这样就知道那些字符应该组合成多字节字符了。
- 如"I♥NY"(I love NewYork)的编码为49(I) E2 99 A5(♥) 4E(N) 59(Y)。
经验证,题目中说的
每个符号包含1到4个非空字符。
就是指每个符号长度不超过4个字节。因此存储需要char[3][10][5]数组即可。
2 表情符号读取:
在之前的1024. 科学计数法 (20)(C语言实现)中,我使用了格式化字符串"%[^...]"
,这种字符串的作用类似于"%s"
,但是后者会读取字符串到空白字符(空格、换行、制表符等等),前者使scanf读到^后面的字符,相当于用户可以自定义scanf的行为。所以这是这道题的一把利剑啊!
代码
最新代码@github,欢迎交流 ^_^
#include <stdio.h>/* https://en.wikipedia.org/wiki/Variable-width_encoding */int main(){ char c, symbols[3][10][5] = {0}; for(int symbol = 0; symbol < 3; symbol++) { int index = 0; while((c = getchar()) != '\n') if(c == '[') scanf("%[^]]", symbols[symbol][index++]); } int N, m[5]; scanf("%d", &N); for(int i = 0; i < N; i++) { for(int i = 0; i < 5; i++) scanf("%d", m + i); if(m[0] > 0 && m[0] <= 10 && *symbols[0][m[0] - 1] && m[1] > 0 && m[0] <= 10 && *symbols[1][m[1] - 1] && m[2] > 0 && m[0] <= 10 && *symbols[2][m[2] - 1] && m[3] > 0 && m[0] <= 10 && *symbols[1][m[3] - 1] && m[4] > 0 && m[0] <= 10 && *symbols[0][m[4] - 1]) printf("%s(%s%s%s)%s\n", symbols[0][m[0] - 1], symbols[1][m[1] - 1], symbols[2][m[2] - 1], symbols[1][m[3] - 1], symbols[0][m[4] - 1]); else puts("Are you kidding me? @\\/@"); } return 0;}
- PAT Basic 1052. 卖个萌 (20)(C语言实现)
- PAT Basic 1004. 成绩排名 (20)(C语言实现)
- PAT Basic 1009. 说反话 (20)(C语言实现)
- PAT Basic 1012. 数字分类 (20)(C语言实现)
- PAT Basic 1013. 数素数 (20)(C语言实现)
- PAT Basic 1019. 数字黑洞 (20)(C语言实现)
- PAT Basic 1027. 打印沙漏(20)(C语言实现)
- PAT Basic 1028. 人口普查(20)(C语言实现)
- PAT Basic 1029. 旧键盘(20)(C语言实现)
- PAT Basic 1034. 有理数四则运算(20)(C语言实现)
- PAT Basic 1042. 字符统计(20)(C语言实现)
- PAT Basic 1043. 输出PATest(20)(C语言实现)
- PAT Basic 1044. 火星数字(20)(C语言实现)
- PAT Basic 1047. 编程团体赛(20)(C语言实现)
- PAT Basic 1048. 数字加密(20)(C语言实现)
- PAT Basic 1054. 求平均值 (20)(C语言实现)
- PAT Basic 1057. 数零壹(20)(C语言实现)
- PAT Basic 1058. 选择题(20)(C语言实现)
- PAT Basic 1047. 编程团体赛(20)(C语言实现)
- PAT Basic 1048. 数字加密(20)(C语言实现)
- PAT Basic 1049. 数列的片段和(20)(C语言实现)
- PAT Basic 1050. 螺旋矩阵(25)(C语言实现)
- PAT Basic 1051. 复数乘法 (15)(C语言实现)
- PAT Basic 1052. 卖个萌 (20)(C语言实现)
- PAT Basic 1053. 住房空置率 (20)(C语言实现)
- PAT Basic 1054. 求平均值 (20)(C语言实现)
- PAT Basic 1055. 集体照 (25)(C语言实现)
- [PAT-乙级]1060.爱丁顿数
- PAT Basic 1056. 组合数的和(15)(C语言实现)
- PAT Basic 1057. 数零壹(20)(C语言实现)
- JS及jQuery获取各种宽度、高度的简单介绍以及判断滚动条滚动到底部事件
- PAT Basic 1058. 选择题(20)(C语言实现)