1052. 卖个萌 (20)
2016-05-29 16:47
239 查看
1052. 卖个萌 (20)
时间限制 400 ms内存限制 65536 kB
代码长度限制 8000 B
判题程序 Standard
作者 CHEN, Yue
萌萌哒表情符号通常由“手”、“眼”、“口”三个主要部分组成。简单起见,我们假设一个表情符号是按下列格式输出的:
左手[右手]
现给出可选用的符号集合,请你按用户的要求输出表情。
输入格式:
输入首先在前三行顺序对应给出手、眼、口的可选符号集。每个符号括在一对方括号[]内。题目保证每个集合都至少有一个符号,并不超过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? @\/@
原题地址: https://www.patest.cn/contests/pat-b-practise/1052
注意输出Are you kidding me? @\/@, 其中的 ‘\’ 要写两个。
#include <iostream> #include <algorithm> #include <cmath> #include <cstdio> #include <cstring> #include <cctype> using namespace std; void solve() { char em[3][20][10] = {0}; int len[3] = {0}; for(int i = 0; i < 3; i ++){ len[i] = 0; int j = 0; bool flag = false; char ch; while((ch = getchar()) != '\n'){ if(ch == '['){ flag = true; len[i] ++; j = 0; } else if(ch == ']'){ flag = false; } else if(flag){ em[i][len[i]][j ++] = ch; } } } int K; cin >> K; for(int i = 0; i < K; i ++){ int lHand, lEye, mouth, rEye, rHand; cin >> lHand >> lEye >> mouth >> rEye >> rHand; int w = false; if(lHand < 1 || lHand > len[0] || rHand < 1 || rHand > len[0]) w = true; if(lEye < 1 || lEye > len[1] || rEye < 1 || rEye > len[1]) w = true; if(mouth < 1 || mouth > len[2]) w = true; if(w){ cout << "Are you kidding me? @\\/@" << endl; continue; } cout << em[0][lHand] << "(" << em[1][lEye] << em[2][mouth] << em[1][rEye] << ")" << em[0][rHand] << endl; } } int main() { solve(); return 0; }
相关文章推荐
- libdvbpsi源码分析(四)PAT表解析/重建
- PAT配置
- 什么是端口复用动态地址转换(PAT) 介绍配置实例
- MikroTik layer7-protocol
- PAT是如何工作的
- PAT 乙级题:1002. 写出这个数 (20)
- PAT (Advanced Level) Practise 1001-1010
- 数据结构学习与实验指导(一)
- PAT Basic Level 1001-1010解题报告
- PAT 数素数
- PAT 福尔摩斯的约会
- PAT 德才论
- PAT 月饼
- 1001. 害死人不偿命的(3n+1)猜想
- 1002. 写出这个数
- 1032. 挖掘机技术哪家强
- 1001. 害死人不偿命的(3n+1)猜想 (PAT basic)
- 1002. 写出这个数(PAT Basic)
- 1004. 成绩排名(PAT Basic)
- 1006. 换个格式输出整数(PAT Basic)