A115475.异或后缀排列

普及+/提高

官方

通过率:0%

时间限制:1.00s

内存限制:128MB

题目描述

给定一个正整数 nn

你需要构造一个 1n1\sim n 的排列 p1,p2,,pnp_1,p_2,\dots,p_n,使得对于每个 ii1in11\le i\le n-1),都能在后缀区间 [i,n][i,n] 中找到某个位置 jj,满足:

pi=pji,p_i = p_j \oplus i,

其中 \oplus 表示按位异或。

如果存在这样的排列,输出任意一个;否则输出 1-1

输入格式

第一行一个整数 tt,表示测试组数。

对于每组数据,仅一行一个整数 nn

输出格式

对每组数据:

  • 若无解,输出 -1
  • 若有解,输出一行 nn 个整数,表示任意一个合法排列。

输入输出样例

  • 输入#1

    2
    3
    4
    

    输出#1

    2 1 3
    -1

说明/提示

数据范围

  • 1t1041 \le t \le 10^4
  • 3n2×1053 \le n \le 2\times 10^5
  • 所有测试组的 nn 之和不超过 2×1052\times 10^5
首页