11582: 【原1582】NC的颜文字
题目
题目描述
author: Spy 原OJ链接:https://acm.sjtu.edu.cn/OnlineJudge-old/problem/1582
Description
Gaygay的NC喜欢和萌萌的璐璐聊天。
但是璐璐不爱搭理他。
悲伤的NC跑去问大大,大大说:一定是你的毛太多了。
(╯‵□′)╯︵┴─┴
悲伤double的NC跑去问Spy,Spy说:你必须要变得足够萌。
“-请告诉我变萌的方法吧!”
“[email protected]毛奶奶”
和美人鱼公主一样,NC从毛奶奶那里用两块腹肌换来了变萌的秘方。
秘方上的技能如下:
技能:初级颜文字
说明:由“手”、“眼”、“口”三个主要部分组成。
格式:[左手][(][左眼][口][右眼][)][右手]
范例:╮(╯▽╰)╭
<(•˘_˘•)>
๑(•̀ㅂ•́)و✧
除了秘方,靠谱的毛奶奶还附赠了用来组合表情的符号库。
请你按照NC的要求,帮他输出颜文字,向璐璐卖萌。
Input Format
输入首先在前三行顺序对应给出手、眼、口的可选符号集。每种符号括在一对方括号[ ]内。题目保证每个集合都至少有一种符号,并不超过15种符号;每种符号包含1到4个非空字符。
之后一行给出一个正整数K,为用户请求的个数。随后K行,每行给出一个NC的符号选择,顺序为左手、左眼、口、右眼、右手——这里只给出符号在相应集合中的序号(从1开始),数字间以空格分隔。
Output Format
对NC的每个要求,在一行中输出生成的表情。若NC选择的序号不存在,则输出“Are you kidding me? \(`Д´)/”。
Sample Input
[╮][╭][o][~\][/~] [<][>]
[╯][╰][^][-][=][>][<][@][⊙]
[Д][▽][_][ε][^] ...
4
1 1 2 2 2
6 8 1 5 5
3 3 4 3 3
2 10 3 9 3
Sample Output
╮(╯▽╰)╭
<(@Д=)/~
o(^ε^)o
Are you kidding me? \(`Д´)/
FineArtz's solution
/* NC的颜文字 */
#include <iostream>
#include <cstdio>
#include <vector>
#include <string>
using namespace std;
const char none[] = "Are you kidding me? \\(`Д´)/";
/*void init(vector<string> &vs){
char ch;
ch = cin.get();
while (ch != '\n'){
if (ch == '['){
string temps = "";
ch = cin.get();
while (ch != ']'){
if (ch == '\n') return;
temps += ch;
ch = cin.get();
}
if (temps != "" && vs.size() < 15)
vs.push_back(temps);
}
ch = cin.get();
}
}*/
int main(){
vector<string> lib[3];
char ch;
for (int i = 0; i != 3; ++i){
while ((ch = cin.get()) != '\n'){
if (ch == '['){
string temps;
while ((ch = cin.get()) != ']')
temps += ch;
//if (lib[i].size() < 15)
lib[i].push_back(temps);
}
}
}
/*for (int i = 0; i != 3; ++i)
for (int j = 0; j != lib[i].size(); ++j)
cout << lib[i][j] << endl;*/
int k;
cin >> k;
for (int query = 0; query != k; ++query){
int q[5] = {0};
string ans = "";
for (int i = 0; i != 5; ++i)
cin >> q[i];
if (q[0] > lib[0].size() || q[0] <=0){
cout << none << endl;
continue;
}
ans += lib[0][q[0] - 1];
ans += "(";
if (q[1] > lib[1].size() || q[1] <=0){
cout << none << endl;
continue;
}
ans += lib[1][q[1] - 1];
if (q[2] > lib[2].size() || q[2] <=0){
cout << none << endl;
continue;
}
ans += lib[2][q[2] - 1];
if (q[3] > lib[1].size() || q[3] <=0){
cout << none << endl;
continue;
}
ans += lib[1][q[3] - 1];
ans += ")";
if (q[4] > lib[0].size() || q[4] <=0){
cout << none << endl;
continue;
}
ans += lib[0][q[4] - 1];
cout << ans << endl;
}
/*for (int i = 0; i != 3; ++i)
{
for (int j = 0; j != lib[i].size(); ++j){
for (int k = 0; k != lib[i][j].size(); ++k)
cout << int(lib[i][j][k]) << ' ';
cout << endl;
}
}*/
return 0;
}