/*
题意:输入在前三行顺序给出可选的集合,保证每个集合至少有一个符号,每个符号包含1~4个非空字符
之后给出一个正整数K,随后K行,左手,左眼,口,右眼,右手,(符号从1开始)数据以空格间隔,求给出表情,入股表情不在则输出balabla
解题:
每行符号不超过10个
1、用一个二维可变数组,即数组元素也是vector
2、读入一整行,扫描这一行,然后就是遇到[,遇到],
用两个数字,j和k,J遇到[,k++,while_if_while_if
3、然后调用sub压入数组
4、最后用一个循环+if,判断是否超出需要,是则continue,不是则继续循环
learn && wrong
1、如果实现四个字符呢,有可能存在四个字符的,vector< vector<string> >非常用去
2、注意substr,字符串起点,读入几个字符
3、这个扫描挺有趣的
*/
#include <iostream>
using namespace std;
char c[4][10];
int main()
{
#include <vector>
using namespace std;
int main() {
vector<vector<string> > v;
for (int i = 0; i < 3; i++) {
string s;
getline(cin, s);
vector<string> row;
int j = 0, k = 0;
while (j < s.length()) {
if (s[j] == '[') {
while (k++ < s.length()) {
if (s[k] == ']') {
row.push_back(s.substr(j + 1, k - j - 1));
break;
}
}
}
j++;
}
v.push_back(row);
}
int n;
cin >> n;
for (int i = 0; i < n; i++) {
int a, b, c, d, e;
cin >> a >> b >> c >> d >> e;
if (a > v[0].size() || b > v[1].size() || c > v[2].size() || d > v[1].size() || e > v[0].size() || a < 1 || b < 1 || c < 1 || d < 1 || e < 1) {
cout << "Are you kidding me? @\\/@" << endl;
continue;
}
cout << v[0][a - 1] << "(" << v[1][b - 1] << v[2][c - 1] << v[1][d - 1] << ")" << v[0][e - 1] << endl;
}
return 0;
}
}