1052 卖个萌 (20分)

本文介绍了一种基于用户选择的手、眼、口符号组合生成萌萌哒表情的算法。通过使用C++和标准模板库(STL),特别是vector容器,实现了表情的动态存储和输出。文章详细解释了如何从输入中解析符号,以及如何根据用户指定的序号输出相应的表情,包括错误处理机制。

1052 卖个萌 (20分)

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

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

现给出可选用的符号集合,请你按用户的要求输出表情。

输入格式:

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

分析:因为不不知道⼀一⾏行行有多少个表情,所以⽤用⼀一个string类型的不不定⻓长⼆二维数组vector存储表情包,以 及可以调⽤用v.size()顺便便解决不不知道⼀一⾏行行有多少个表情的问题~~
不不定⻓长数组共三⾏行行,分别对应输⼊入⽤用例例的三⾏行行~只不不过在存储如数组之前把它们的⽅方括号去掉在存储~ 这⾥里里可以⽤用string的substr⽅方法实现~然后根据输⼊入的数字序号输出对应的表情~耶耶耶能从这道题⾥里里 ⾯面复习好多知识点呢~~
注意:1.“Are you kidding me? @\/@”的’\’是转义字符,想要输出’\’就要⽤用’\’表示~
2.第⼀一个测试点⾥里里⾯面包含了了空格,所以⽤用cin会失败的,要⽤用getline才能读⼊入⼀一⾏行行字符串串~ 

 

#include<iostream>
#include<stdio.h>
#include<string.h>
#include<vector>
using namespace std;
int main()
{
    vector<vector<string> >p;

    for(int i=0; i<3; i++)
    {      string s;
        getline(cin,s);
        vector<string>q;
        int j=0;
        int k=0;
        while(j<(int)s.length())
        {
            if(s[j]=='[')
            {
                while(k++<(int)s.length())
                {
                    if(s[k]==']')
                    {
                        q.push_back(s.substr(j+1,k-j-1));
                        break;
                    }
                }
            }
            j++;
        }
        p.push_back(q);
    }
    int n;
    scanf("%d",&n);
    for(int i=0; i<n; i++)
    {
        int a,b,c,d,e;
        scanf("%d%d%d%d%d",&a,&b,&c,&d,&e);
        if(p[0].size()<a||p[1].size()<b||p[2].size()<c||p[1].size()<d||p[0].size()<e||a<1||b<1||c<1||d<1||e<1)
        {
            cout<<"Are you kidding me? @\\/@"<<endl;
            continue;
        }
        cout<<p[0][a-1]<<"("<<p[1][b-1]<<p[2][c-1]<<p[1][d-1]<<")"<<p[0][e-1]<<endl;
    }
    return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值