You are given a binary string $$$s$$$ of length $$$2n$$$ where each element is $$$\mathtt{0}$$$ or $$$\mathtt{1}$$$. You can do the following operation:
Your task is to find a sequence of no more than $$$10$$$ operations that changes all elements of $$$s$$$ to $$$\mathtt{0}$$$, or determine that it is impossible to do so. Note that you do not have to minimize the number of operations.
Under the given constraints, it can be proven that if it is possible to change all elements of $$$s$$$ to $$$\mathtt{0}$$$, there exists a way that requires no more than $$$10$$$ operations.
$$$^\dagger$$$ A sequence of brackets is called balanced if one can turn it into a valid math expression by adding characters $$$+$$$ and $$$1$$$. For example, sequences "(())()", "()", and "(()(()))" are balanced, while ")(", "(()", and "(()))(" are not.
$$$^\ddagger$$$ If we perform a range toggle operation from $$$l$$$ to $$$r$$$ on a binary string $$$s$$$, then we toggle all values of $$$s_i$$$ such that $$$l \leq i \leq r$$$. If $$$s_i$$$ is toggled, we will set $$$s_i := \mathtt{0}$$$ if $$$s_i = \mathtt{1}$$$ or vice versa. For example, if $$$s=\mathtt{1000101}$$$ and we perform a range toggle operation from $$$3$$$ to $$$5$$$, $$$s$$$ will be changed to $$$s=\mathtt{1011001}$$$.
Each test contains multiple test cases. The first line contains the number of test cases $$$t$$$ ($$$1 \le t \le 1000$$$). The description of the test cases follows.
The first line of each test case contains a single integer $$$n$$$ ($$$1 \le n \le 2\cdot 10^5$$$) — where $$$2n$$$ is the length of string $$$s$$$.
The second line of each test case contains a binary string $$$s$$$ of length $$$2n$$$ ($$$s_i = \mathtt{0}$$$ or $$$s_i = \mathtt{1}$$$).
It is guaranteed that the sum of $$$n$$$ over all test cases does not exceed $$$2\cdot 10^5$$$.
For each test case, output $$$-1$$$ in a single line if it is impossible to change all elements of $$$s$$$ to $$$\mathtt{0}$$$.
Otherwise, output a single integer $$$k$$$ ($$$0 \le k \le 10$$$) representing the number of operations needed to change all elements of $$$s$$$ to $$$\mathtt{0}$$$. Then, on each of the next $$$k$$$ lines, output a balanced bracket sequence of length $$$2n$$$ representing the operations needed to change all elements of $$$s$$$ to $$$0$$$s.
If there are multiple ways to change all elements of $$$s$$$ to $$$\mathtt{0}$$$ that require not more than $$$10$$$ operations, you can output any of them.
4101200003100111401011100
-1 2 ()() ()() 1 (())() 2 (((()))) ()()(())
In the first test case, it can be proven that it is impossible to change all elements of $$$s$$$ to $$$\mathtt{0}$$$.
In the second test case, the first operation using the bracket sequence $$$b = \mathtt{()()}$$$ will convert the binary string $$$s=\mathtt{0000}$$$ to $$$s=\mathtt{1111}$$$. Then, the second operation using the same bracket sequence $$$b = \mathtt{()()}$$$ will convert the binary string $$$s=\mathtt{1111}$$$ back to $$$s=\mathtt{0000}$$$. Note that since all elements of $$$s$$$ is already $$$\mathtt{0}$$$ initially, using $$$0$$$ operations is also a valid answer.
In the third test case, a single operation using the bracket sequence $$$b = \mathtt{(())()}$$$ will change all elements of $$$s$$$ to $$$\mathtt{0}$$$. The operation will happen as follows.
In the fourth test case, the first operation using the bracket sequence $$$b = \mathtt{(((())))}$$$ will convert the binary string $$$s = \mathtt{01011100}$$$ to $$$s = \mathtt{11111001}$$$. Then, the second operation using the bracket sequence $$$b = \mathtt{()()(())}$$$ will convert the binary string $$$s = \mathtt{11111001}$$$ to $$$s=\mathtt{00000000}$$$.
Name |
---|