PAT 乙级 1052

题目

萌萌哒表情符号通常由“手”、“眼”、“口”三个主要部分组成。简单起见,我们假设一个表情符号是按下列格式输出的:

[左手]([左眼] [口] [右眼])[右手]

现给出可选用的符号集合,请你按用户的要求输出表情。
输入格式:
输入首先在前三行顺序对应给出手、眼、口的可选符号集。每个符号括在一对方括号 []内。题目保证每个集合都至少有一个符号,并不超过 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? @/@

分析

存单个表情符号的方法很重要

AC代码

#include <iostream>
#include <algorithm>
#include <vector>

using namespace std;

string a, b, c; // 手, 眼, 口

vector<string> a1, b1, c1;

int k;
int op[10];

int main ()
{
    getline(cin, a);
    getline(cin, b);
    getline(cin, c);

    int j, i;

    int cnt_a1 = 0;
    for(i = 0 ; i < a.size() ; i ++ )
        if(a[i] == '[') break;
    for(i = i + 1; i < a.size() ; i ++ )
    {
        string res;
        for(j = i ; a[j] != ']'; j ++ )
        {
            res += a[j];
        }
        a1.push_back(res);
        cnt_a1 ++ ;
        for( ; a[j] != '[' && j < a.size() ; j ++ );
        i = j;
    }

    int cnt_b1 = 0;
    for(i = 0 ; i < b.size() ; i ++ )
        if(b[i] == '[') break;
    for(i = i + 1; i < b.size() ; i ++ )
    {
        string res;
        for(j = i ; b[j] != ']'; j ++ )
        {
            res += b[j];
        }
        b1.push_back(res);
        cnt_b1 ++ ;
        for( ; b[j] != '[' && j < b.size() ; j ++ );
        i = j;
    }

    int cnt_c1 = 0;
    for(i = 0 ; i < c.size() ; i ++ )
        if(c[i] == '[') break;
    for(i = i + 1; i < c.size() ; i ++ )
    {
        string res;
        for(j = i ; c[j] != ']'; j ++ )
        {
            res += c[j];
        }
        c1.push_back(res);
        cnt_c1 ++ ;
        for( ; c[j] != '[' && j < c.size() ; j ++ );
        i = j;
    }

    cin >> k;

    while(k -- )
    {
        for(int i = 0 ; i < 5 ; i ++ ) cin >> op[i];

        if(op[0] > cnt_a1 || op[1] > cnt_b1 || op[2] > cnt_c1 || op[3] > cnt_b1 || op[4] > cnt_a1 || op[0] < 1 || op[1] < 1 || op[2] < 1 || op[3] < 1 || op[4] < 1)
        {
            puts("Are you kidding me? @\\/@");
            continue;
        }
        cout << a1[op[0] - 1] << "(" << b1[op[1] - 1] << c1[op[2] - 1] << b1[op[3] - 1] << ")" << a1[op[4] - 1] << endl;
    }

    return 0;
}
发布了52 篇原创文章 · 获赞 22 · 访问量 1720

猜你喜欢

转载自blog.csdn.net/qq_45792080/article/details/105094659
今日推荐