算法学习之路|卖个萌

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

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

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

输入格式

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

我的思路

利用scanf格式化存入这些符号。

然后根据给的数据,判断是否可以成为一个脸,即可。

代码如下(有个别没有AC):

#include<iostream>
#include<stdio.h>
#include<string>
#include<vector>
using namespace std;
int main(){
    string a;
    vector<string> face[3];//0:手,1:眼,2:口
    for(int j=0;j<3;j++){
        getline(cin,a);
        //cout<<a<<endl;
        for(int l=0,r=0,i=0;;i++,l++,r++){
            while (a[r]!=']'){
                r++;
                if(r>=a.size())
                    break;
                
            }
            if(r>=a.size())
                break;
            while(a[l]!='['){
                l++;
            }
            face[j].push_back(a.substr(l+1,r-l-1));
        }
    }
    
//    for(int j=0;j<3;j++){
//        for(auto a:face[j])
//            cout<<a<<" ";
//        cout<<face[j].size()<<endl;
//    }
    
    int n;
    cin>>n;
    for(int i=0;i<n;i++){
        int tmp[5];
        for(int j=0;j<5;j++){
            cin>>tmp[j];
        }
        if(tmp[0]>face[0].size()||tmp[4]>face[0].size()||tmp[1]>face[1].size()||
           tmp[3]>face[1].size()||tmp[2]>face[2].size()){
            cout<<"Are you kidding me? @\\/@"<<endl;
            continue;
        }
        cout<<face[0][tmp[0]-1]<<"(";
        cout<<face[1][tmp[1]-1];
        cout<<face[2][tmp[2]-1];
        cout<<face[1][tmp[3]-1]<<")";
        cout<<face[0][tmp[4]-1];
        cout<<endl;
    }
    
}
上一篇:asp.net利用GridView"表中表"实现主从表数据


下一篇:吴翰清​(道哥)眼中的机器智能:计算机的再发展