path1 = input()
f1 = open(path1, 'r') # 字典路徑
CNS = {}
CNS = {}
match = set()
for line in f1:
a, b = line.split()
b = chr(int('0x'+b, 16)) # 轉成國字
if b in CNS.keys() and a in CNS[b]:
continue
# 判斷有沒有被匹配過
if a in match:
print("MAPPING_TABLE_ERROR")
exit(0)
match.add(a)
if not b in CNS: # 如果沒有被匹配過要先宣告一個set
sa = []
CNS[b] = sa
CNS[b].append(a)
path2 = input()
f2 = open(path2, 'r') # 注音路徑
PHONETIC = {}
for line in f2:
a, b = line.split()
if a in PHONETIC.keys() and b in PHONETIC[a]:
continue
if not a in PHONETIC: # 如果沒有被匹配過要先宣告一個set
sb = []
PHONETIC[a] = sb
PHONETIC[a].append(b)
target = input()
print(len(PHONETIC)) # 輸出總共有幾個不同的CNS碼
if not target in CNS: # 如果沒有target的CNS碼
print("NO_CNS_DATA")
exit(0)
used = set()
for i in sorted(CNS[target]):
if not i in PHONETIC: # 如果找不到注音碼
print("NO_PHONETIC_DATA")
exit(0)
for j in PHONETIC[i]:
if not j in used: # 如果之前輸出過了就跳過
print(j)
used.add(j)