1052 卖个萌 (20 分)//部分正确

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



部分正确(12分)

#include<iostream>
#include<string>
using namespace std;
void getpic(string t, string hands[], int &n_hands);
int main()
{
  string hands[11];
  int n_hands = 0;
  string eyes[11];
  int n_eyes = 0;
  string mouths[11];
  int n_mouths = 0;
  string t;
  getline(cin, t);
  getpic(t, hands, n_hands);
  getline(cin, t);
  getpic(t, eyes, n_eyes);
  getline(cin, t);
  getpic(t, mouths, n_mouths);
  int n;
  cin >> n;
  int hands1[10000];
  int hands2[10000];
  int eyes1[10000];
  int eyes2[10000];
  int mouth1s[10000];
  for (int i = 0; i < n; i++) {
    cin >> hands1[i] >> eyes1[i] >> mouth1s[i] >> eyes2[i] >> hands2[i];
  }
  for (int i = 0; i < n; i++) {
    int h1=hands1[i], e1=eyes1[i],m= mouth1s[i],
      e2=eyes2[i], h2= hands2[i];
 
    if (h1 > n_hands || e1 > n_eyes || m > n_mouths || e2 > n_eyes || h2 > n_hands)
      cout << "Are you kidding me? @\\/@";
    else {
      cout << hands[h1]<<'(' << eyes[e1] << mouths[m] << eyes[e2] << ')' << hands[h2] << endl;
    }
  }
  return 0;
}
void getpic(string t,string hands[],int &n_hands) {
  int left = 0, right = 0;
  for (int i = 0; i < t.length(); i++) {
    if (t[i] == '[')
      left = i;
    if (t[i] == ']') {
      right = i;
      hands[++n_hands] =  t.substr(left+1, right-left-1);
    }
  }
}
相关文章
|
2月前
7-35 情人节 (15 分)
7-35 情人节 (15 分)
31 0
L2-028 秀恩爱分得快 (25 分)
L2-028 秀恩爱分得快 (25 分)
135 0
【每日一道智力题】之海盗分金币(上)
【每日一道智力题】之海盗分金币(上)
134 0
L1-035 情人节 (15 分)
L1-035 情人节 (15 分)
121 0
L1-035 情人节 (15 分)
|
安全
L3-009 长城 (30 分)(数学知识)
L3-009 长城 (30 分)(数学知识)
190 0
L3-009 长城 (30 分)(数学知识)
|
机器学习/深度学习 人工智能
PTA 7-3 拼题 A 是真爱 (20 分)
如果一个人在一段话里很多次提到 pintia,那对拼题 A 就是真爱啦~ 本题就请你检查一下给定的文字中出现了几次 pintia。
104 0
|
测试技术
PTA 7-1 祖传好运 (15 分)
我们首先定义 0 到 9 都是好运数,然后从某个好运数开始,持续在其右边添加数字,形成新的数字。
106 0
L1-073 人与神 (5 分)
L1-073 人与神 (5 分)
81 0
爱迪生的名言 (5 分)
爱迪生的名言 (5 分)
92 0
|
算法 测试技术
h0103. 末日算法 (10 分)
h0103. 末日算法 (10 分)
208 0