PAT 1052 卖个萌(20 分)

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? @\/@




解析

这题是模拟题,但是真的很有意思。
我的思路是先把表情存在vector< string> data[3]

data[0]是 手 
data[1]是眼
data[2]是嘴

在每次处理一次请求。要判断请求的序号要大于0,小于之前对应的data[0],data[1],data[2]的size();

#include
using namespace std;
int main()
{
  vector<string> data[3];
  int N;
  string str;
  string temp;
  for(int i=0;i<3;i++){
    getline(cin,str);
    int j=-1;
    while(++j !=str.size()){
      if(str[j] =='['){
        while(str[++j] !=']')
          temp+=str[j];
      data[i].push_back(temp);
      temp.clear();
      }
    }
  }
  int d1,d2,d3,d4,d5;
  cin>>N;
  while(N--){
    cin>>d1>>d2>>d3>>d4>>d5;
    bool flag = (d1<1 || d2<1 || d3<1 || d4<1 || d5<1 );
    if( flag || d1 >data[0].size() || d2 >data[1].size() || d3>data[2].size() || d4>data[3].size() || d5>data[4].size() )
      cout<<"Are you kidding me? @\\/@"<else
      cout<0][d1-1]<<"("<1][d2-1]<2][d3-1]<1][d4-1]<<")"<0][d5-1]<

你可能感兴趣的:(PAT-B)