Skip to content

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;
}