CFCF2144F.Bracket Groups

省选/NOI-

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

一个“正规括号序列”是指可以转换为正确的算术表达式的括号序列。例如:

  • 括号序列 "()()" 和 "(())" 是正规的(转换后表达式分别为 "(1)+(1)" 和 "((1+1)+1)");
  • 括号序列 ")(", "(" 和 ")" 不是正规的。

现在给定 nn 个括号序列 s1,s2,,sns_1, s_2, \dots, s_n(不一定是正规括号序列),以及一个偶数 kk。你的任务是将它们划分到若干组中,满足:

  • 每个括号序列恰好属于一个组;
  • 对于每一组,存在一个长度恰好为 kk 的正规括号序列,使得该组内的任意一个括号序列都不是这个正规括号序列的子串。

请问,最少需要多少组才能满足上述要求?如果无法实现,则输出 1-1。否则,输出分组方案和每组对应的任意一个长度为 kk 的正规括号序列。如果存在多个最优方案,任意输出一个即可。

输入格式

第一行包含两个整数 nnkk1n501 \le n \le 502k502 \le k \le 50kk 是偶数。

接下来的 nn 行中,第 ii 行包含一个括号序列 sis_i2sik2 \le |s_i| \le k),仅包含字符 '(' 和 ')'。

输出格式

如果无法按照要求分组,输出 1-1

否则,第一行输出最小分组数 mm。接下来 mm 组,每组包含三行:

  • 第一行包含一个长度为 kk 的正规括号序列;
  • 第二行包含一个整数 gg,表示本组中括号序列的数量;
  • 第三行包含 gg 个整数,表示本组包含的括号序列在输入中的编号。

要求本组中任意一个括号序列都不是该正规括号序列的子串。每个编号 1n1 \sim n 只出现一次。

若存在多个最优解,输出任意一个。

输入输出样例

  • 输入#1

    3 6
    )))
    (((
    (())

    输出#1

    1
    (()())
    3
    1 2 3
首页