#include <iostream>
#include <string>
#include <vector>
using namespace std;
struct node{
string name;
string up;
node(string n, string u){
name = n;
up = u;
}
};
vector<node> v;
void init(string str){
string temp = "root";
string up = "root";
int i, j;
for(i = 0; i < str.size(); ++i){
if('a' <= str[i] && str[i] <= 'z'){
temp = "";
while('a' <= str[i] && str[i] <= 'z'){
temp += str[i];
++i;
}
--i;
v.push_back(node(temp, up));
}else if(str[i] == '('){
up = temp;
}else if(str[i] == ')'){
for(j = 0; j < v.size(); ++j){
if(v[j].name == up){
up = v[j].up;
break;
}
}
}
}
}
string findUp(string name){
int i;
for(i = 0; i < v.size(); ++i){
if(v[i].name == name){
return v[i].up;
}
}
}
int main(int argc, char *argv[]) {
string str, name;
int i;
cin>>str;
init(str);
while(cin>>name){
vector<string> result;
result.push_back(name);
string up = findUp(name);
result.push_back(up);
while(up != "root"){
up = findUp(up);
if(up != "root"){
result.push_back(up);
}
}
for(i = result.size() - 1; i >= 1; --i){
cout<<result[i]<<">";
}
cout<<result[0]<<endl;
}
return 0;
}