#include using namespace std; #define rep(i, x, limit) for (long long i = (long long)x; i < (long long)limit; i++) #define REP(i, x, limit) for (long long i = (long long)x; i <= (long long)limit; i++) #define all(x) x.begin(), x.end() #define rall(x) x.rbegin(), x.rend() #define el '\n' #define spa " " #define Yes cout << "Yes" << el #define No cout << "No" << el #define YES cout << "YES" << el #define NO cout << "NO" << el #define eps (1e-10) #define Equals(a,b) (fabs((a) - (b)) < eps ) #define debug(x) cerr << #x << " = " << x << el using ll = long long; using ull = unsigned long long; using pii = pair; using pll = pair; using vi = vector; using vl = vector; using vvl = vector>; using vs = vector; using vb = vector; const double pi = 3.141592653589793238; const int inf = 1073741823; const ll infl = 1LL << 60; const string ABC = "ABCDEFGHIJKLMNOPQRSTUVWXYZ"; const string abc = "abcdefghijklmnopqrstuvwxyz"; const ll MOD = 998244353; #include using namespace atcoder; using mint = modint998244353; using vm = vector; int main() { ios::sync_with_stdio(false); cin.tie(nullptr); ll n;cin>>n; vector> C(n,vector(4)); rep(i,0,n){ string c1,c2,c3,c4;cin>>c1>>c2>>c3>>c4; ll cc1,cc2,cc3,cc4; if(c1!="H")cc1=stoi(c1)-1; else cc1=-1; if(c2!="H")cc2=stoi(c2)-1; else cc2=-1; if(c3!="H")cc3=stoi(c3)-1; else cc3=-1; if(c4!="H")cc4=stoi(c4)-1; else cc4=-1; C[i]={cc1,cc2,cc3,cc4}; } vb visited(n,false); auto dfs=[&](auto&&f,ll now)->string{ visited[now]=true; string s=""; rep(i,0,4){ auto &c=C[now][i]; if(c==-1)continue; ll ci=c; if(visited[ci])continue; s+='('; s+=f(f,ci); s+=')'; } s+=(now==0?"methane":"methyl"); return s; }; cout<