CF2189C2 XOR-convenience (Hard Version)

题目描述

这是此问题的困难版本。不同版本之间的区别在于,在此版本中,$1 \le i \le n-1$。请注意,困难版本的正确解不一定是简单版本的正确解。 给定一个正整数 $n$。求一个长度为 $n$ 的排列 $ ^{\text{∗}} $ $p$,使得对于每个 $i$($1 \le i \le n-1$),都存在一个 $j$($i \le j \le n$)使得 $^\text{†}$ $p_i = p_j \oplus i$,或者判断这样的排列不存在。 $ ^{\text{∗}} $ 长度为 $n$ 的排列是一个包含从 $1$ 到 $n$ 的 $n$ 个不同整数的数组,顺序任意。例如,$[2,3,1,5,4]$ 是一个排列,但 $[1,2,2]$ 不是排列($2$ 在数组中出现两次),$[1,3,4]$ 也不是排列($n=3$ 但数组中有 $4$)。 † $\oplus$ 表示按位异或操作。

输入格式

每个测试包含多个测试用例。第一行包含测试用例的数量 $t$($1 \le t \le 10^4$)。测试用例的描述如下。 每个测试用例只有一行,包含一个正整数 $n$($3 \leq n \leq 2 \times 10^5$)——排列的长度。 保证所有测试用例的 $n$ 的总和不超过 $2 \times 10^5$。

输出格式

对于每个测试用例,如果存在合适的排列,则输出 $n$ 个整数 $p_1, p_2, \ldots, p_n$ —— 排列 $p$。否则输出 $-1$。 如果存在多个解,输出其中任意一个。

说明/提示

在第一个测试用例中,排列 $p = [2,1,3]$ 满足条件,因为: - $p_2 = 1$ - $p_3 \oplus 2 = 3 \oplus 2 = 1$ 在第二个测试用例中,没有合适的排列。