CF2143E Make Good

题目描述

给定一个长度为 $n$ 的括号字符串 $s$。你可以对其执行如下任意次数(可以为零次,顺序不限)的操作: - 选择一个下标 $1 \leq i < |s|$,若 $s_i = s_{i+1} = ($,则将 $s_i$ 和 $s_{i+1}$ 都替换为 $)$。 - 选择一个下标 $1 \leq i < |s|$,若 $s_i = s_{i+1} = )$,则将 $s_i$ 和 $s_{i+1}$ 都替换为 ($。 找出一个可以通过上述操作从 $s$ 得到的合法括号序列 $t$,如果不存在则输出 $-1$。 *一个合法的括号序列是指,通过在原序列的括号之间插入“1”和“+”字符,可以得到一个正确的算术表达式。例如:括号序列 "()()" 和 "(())" 是合法的(对应表达式为 "(1)+(1)" 和 "((1+1)+1)");而")("、"(" 和 ")"都是不合法的。*

输入格式

每组测试包含多组数据。第一行包含一个整数 $t$($1 \leq t \leq 10^4$),表示测试用例的数量。 每个测试用例的第一行包含一个整数 $n$($1 \leq n \leq 2 \times 10^5$),表示字符串的长度。 第二行包含一个仅由字符 "(" 和 ")" 组成的、长度为 $n$ 的字符串 $s$。 保证所有测试用例的 $n$ 之和不超过 $2 \times 10^5$。

输出格式

对于每个测试用例,输出可以通过操作得到的一个合法括号序列 $t$。如果无法得到合法括号序列,输出 $-1$。

说明/提示

在第一个测试用例中,字符串"()()"已经是一个合法的括号序列,无需任何操作。 在第二个和第三个测试用例中,无法通过操作将 $s$ 变为合法括号序列。 在第四个测试用例中,可以如下操作: "))))))))" $\xrightarrow{i = 1}$ "(())))))" "(())))))" $\xrightarrow{i = 5}$ "(())(())"。 由 ChatGPT 5 翻译