CF2144F Bracket Groups
题目描述
一个“正规括号序列”是指可以转换为正确的算术表达式的括号序列。例如:
- 括号序列 "()()" 和 "(())" 是正规的(转换后表达式分别为 "(1)+(1)" 和 "((1+1)+1)");
- 括号序列 ")(", "(" 和 ")" 不是正规的。
现在给定 $n$ 个括号序列 $s_1, s_2, \dots, s_n$(不一定是正规括号序列),以及一个偶数 $k$。你的任务是将它们划分到若干组中,满足:
- 每个括号序列恰好属于一个组;
- 对于每一组,存在一个长度恰好为 $k$ 的正规括号序列,使得该组内的任意一个括号序列都不是这个正规括号序列的子串。
请问,最少需要多少组才能满足上述要求?如果无法实现,则输出 $-1$。否则,输出分组方案和每组对应的任意一个长度为 $k$ 的正规括号序列。如果存在多个最优方案,任意输出一个即可。
输入格式
第一行包含两个整数 $n$ 和 $k$,$1 \le n \le 50$,$2 \le k \le 50$,$k$ 是偶数。
接下来的 $n$ 行中,第 $i$ 行包含一个括号序列 $s_i$($2 \le |s_i| \le k$),仅包含字符 '(' 和 ')'。
输出格式
如果无法按照要求分组,输出 $-1$。
否则,第一行输出最小分组数 $m$。接下来 $m$ 组,每组包含三行:
- 第一行包含一个长度为 $k$ 的正规括号序列;
- 第二行包含一个整数 $g$,表示本组中括号序列的数量;
- 第三行包含 $g$ 个整数,表示本组包含的括号序列在输入中的编号。
要求本组中任意一个括号序列都不是该正规括号序列的子串。每个编号 $1 \sim n$ 只出现一次。
若存在多个最优解,输出任意一个。
说明/提示
由 ChatGPT 5 翻译