loj#P6859. 「ICPC World Finals 2021」史前程序
「ICPC World Finals 2021」史前程序
Description
Archaeologists have discovered exciting clay tablets in deep layers of Alutila Cave. Nobody was able to decipher the script on the tablets, except for two symbols that seem to describe nested structures not unlike opening and closing parentheses in LISP. Could it be that humans wrote programs thousands of years ago?
Taken together, the tablets appear to describe a great piece of work – perhaps a program, or an epic, or even tax records! Unsurprisingly, after such a long time, the tablets are in a state of disorder. Your job is to arrange them into a sequence so that the resulting work has a properly nested parenthesis structure. Considering only opening and closing parentheses, a properly nested structure is either
()
, or(A)
, where is a properly nested structure, orAB
, where and are properly nested structures.
Input
The first line of input contains one integer (), the number of tablets. Each of the remaining lines describes a tablet, and contains a non-empty string of opening and closing parentheses; symbols unrelated to the nesting structure are omitted. The strings are numbered from to in the order that they appear in the input. The input contains at most parentheses.
Output
Output a permutation of the numbers from to such that concatenating the strings in this order results in a properly nested structure. If this happens for multiple permutations, any one of them will be accepted. If there is no such permutation, output impossible
instead.
2
())())()
((()
2
1
5
(
))
((
))
(
1
5
3
2
4
2
((
)
impossible