import sys input = sys.stdin.readline from operator import itemgetter N=int(input()) C=[input().split() for i in range(N)] E=[[] for i in range(N)] for i in range(N): for j in range(4): if C[i][j]=="H": continue x=int(C[i][j])-1 E[i].append(x) # 木のHL分解+LCA ROOT=0 QUE=[ROOT] Parent=[-1]*N Parent[ROOT]=N # ROOTの親を定めておく. Child=[[] for i in range(N)] TOP_SORT=[] # トポロジカルソート while QUE: # トポロジカルソートと同時に親を見つける x=QUE.pop() TOP_SORT.append(x) for to in E[x]: if Parent[to]==-1: Parent[to]=x Child[x].append(to) QUE.append(to) Children=[1]*N for x in TOP_SORT[::-1]: #(自分を含む)子ノードの数を調べる if x==ROOT: break Children[Parent[x]]+=Children[x] DP=[[] for i in range(N)] for x in TOP_SORT[::-1]: #print(DP) if Child[x]==[]: DP[x]=["(methyl)"] else: LIST=[] for c in Child[x]: LIST.append((Children[c],c)) LIST.sort(key=itemgetter(0),reverse=True) NOW=["("] for _,c in LIST: if NOW==[]: NOW=DP[c] NOW[0]="("+NOW[0] else: NOW+=DP[c] NOW.append("methyl") NOW.append(")") DP[x]=NOW ANS=DP[0][1:] ANS.pop() ANS[-1]="methane" print("".join(ANS))