/*
題意:輸入在前三行順序給出可選的集合婉支,保證每個集合至少有一個符號鸯隅,每個符號包含1~4個非空字符
之后給出一個正整數(shù)K,隨后K行向挖,左手蝌以,左眼炕舵,口,右眼跟畅,右手咽筋,(符號從1開始)數(shù)據(jù)以空格間隔,求給出表情碍彭,入股表情不在則輸出balabla
解題:
每行符號不超過10個
1晤硕、用一個二維可變數(shù)組,即數(shù)組元素也是vector
2庇忌、讀入一整行舞箍,掃描這一行,然后就是遇到[,遇到]皆疹,
用兩個數(shù)字疏橄,j和k,J遇到[略就,k++捎迫,while_if_while_if
3、然后調(diào)用sub壓入數(shù)組
4表牢、最后用一個循環(huán)+if窄绒,判斷是否超出需要,是則continue崔兴,不是則繼續(xù)循環(huán)
learn && wrong
1彰导、如果實現(xiàn)四個字符呢,有可能存在四個字符的敲茄,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;
}
}