CF2130B Pathless
题目描述
有一个由数值 $ 0 $、$ 1 $、$ 2 $ 和一个整数 $ s $ 构成的数组 $ a_1, a_2, \ldots, a_n $。保证数组中至少有一个 $ 0 $,一个 $ 1 $ 和一个 $ 2 $。
爱丽丝想要从下标 $1$ 开始向左或向右移动几步(每一步的距离为 $1$),最终达到点 $n$。当爱丽丝移动的时候,她计算她经过的格子中的数值和,并且,她想要使得结束时的和恰好等于 $s$。
正式的说,爱丽丝想要找到一个下标的序列 $ [i_1, i_2, \ldots, i_m] $,满足:
- $ i_1 = 1 $ , $ i_m = n $ ;
- 对于所有的 $ 1 \le j \le m $,条件 $ 1 \leq i_j \leq n $ 满足;
- 对于所有的 $ 1 \leq j < m $,条件 $ |i_{j} - i_{j+1}| = 1 $ 满足;
- $ a_{i_1} + a_{i_2} + \ldots + a_{i_m} = s $ 。
不过,鲍勃想要重新排列 $ a_1, a_2, \ldots, a_n $ 以防止爱丽丝达到她的目标。 你需要决定重新排列数组 $ a_1, a_2, \ldots, a_n $ 是否能够使得爱丽丝不能找到她的目标(下标)序列(就算爱丽丝足够聪明)。如果可行,你也需要输出重新排列后的数组 $ a_1, a_2, \ldots, a_n $。
输入格式
每一组数据包含多组测试。第一行包含数据组数 $t$($ 1 \le t \le 10^3 $)。对于每一组测试数据的描述如下所示:
对于每组数据,
第一行包含了两个整数 $n$ 和 $s$($ 3 \le n \le 50 $,$ 0 \le s \le 1000 $)。
第二行包含了 $n$ 个整数 $ a_1, a_2, \ldots, a_n $,描述数组 $a$($ 0 \le a_i \le 2 $)。
同题目描述所示,保证数组中至少有一个 $ 0 $,一个 $ 1 $ 和一个 $ 2 $。
输出格式
对于每一组测试数据,如果重新排列数组 $a$ 使得爱丽丝找不到她的目标序列,输出 $n$ 个整数,表示重新排列后的数组 $a$。否则输出 $-1$。
每组数据用换行分隔。
说明/提示
### 输入输出样例 #1 解释
在第一组数据中,任何的重新排列都能使得爱丽丝无法达到她的目标。
在第二组数据中,无论如何怎么重新排列数组 $a$,爱丽丝都能找到序列 $ [1,2,3] $ 作为她的目标序列。
在第三组数据中,没有一种重新排列的结果能够防止爱丽丝找到她的目标序列。举个例子,对于 $ a=[0,2,1] $,爱丽丝能够找到序列 $ [1,2,3,2,3] $ 作为她的目标序列。