词链

题目描述

如果单词 $X$ 的末字母与单词 $Y$ 的首字母相同,则 $X$ 与 $Y$ 可以相连成 $X.Y$。(注意:$X$、$Y$ 之间是英文的句号 `.`)。例如,单词 `dog` 与单词 `gopher`,则 `dog` 与 `gopher` 可以相连成 `dog.gopher`。 另外还有一些例子: - `dog.gopher` - `gopher.rat` - `rat.tiger` - `aloha.aloha` - `arachnid.dog` 连接成的词可以与其他单词相连,组成更长的词链,例如: `aloha.arachnid.dog.gopher.rat.tiger` 注意到,`.` 两边的字母一定是相同的。 现在给你一些单词,请你找到字典序最小的词链,使得每个单词在词链中出现且仅出现一次。注意,相同的单词若出现了 $k$ 次就需要输出 $k$ 次。

输入输出格式

输入格式


第一行是一个正整数 $n$($1 \le n \le 1000$),代表单词数量。 接下来共有 $n$ 行,每行是一个由 $1$ 到 $20$ 个小写字母组成的单词。

输出格式


只有一行,表示组成字典序最小的词链,若不存在则只输出三个星号 `***`。

输入输出样例

输入样例 #1

6
aloha
arachnid
dog
gopher
rat
tiger

输出样例 #1

aloha.arachnid.dog.gopher.rat.tiger

说明

- 对于 $40\%$ 的数据,有 $n \leq 10$; - 对于 $100\%$ 的数据,有 $n \leq 1000$。