#CF1971G. XOUR

    ID: 6898 传统题 1000ms 256MiB 尝试: 1 已通过: 1 难度: 10 上传者: 标签>数据结构并查集排序CodeforcesCodeforces Round 944(Div4)Div4GCF1971G1700

XOUR

题目描述

给定一个由 nn 个非负整数组成的数组 aa

你可以交换位置 iijj 上的元素,当且仅当 ai XOR aj<4a_i~\mathsf{XOR}~a_j < 4,其中 XOR\mathsf{XOR} 表示按位异或运算

请找出通过任意次数的合法交换后,能够得到的字典序最小的数组。

如果在第一个不同的位置 xxyy 满足 xi<yix_i < y_i,则数组 xx 的字典序小于数组 yy

输入格式

第一行包含一个整数 tt1t1041 \leq t \leq 10^4),表示测试用例的数量。

每个测试用例的第一行包含一个整数 nn1n21051 \leq n \leq 2 \cdot 10^5),表示数组的长度。

每个测试用例的第二行包含 nn 个整数 aia_i0ai1090 \leq a_i \leq 10^9),表示数组的元素。

保证所有测试用例中 nn 的总和不超过 21052 \cdot 10^5

输出格式

对于每个测试用例,输出 nn 个整数,表示通过任意次数的合法交换后能够得到的字典序最小的数组。

样例

4
4
1 0 3 2
5
2 7 1 5 6
8
1 2 1 2 1 2 1 2
4
16 4 1 64
0 1 2 3 
1 5 2 6 7 
1 1 1 1 2 2 2 2 
16 4 1 64

样例说明

对于第一个测试用例,你可以交换任意两个元素,因此可以得到排序后的数组。

对于第二个测试用例,你可以交换 2211(它们的 XOR\mathsf{XOR}33),7755(它们的 XOR\mathsf{XOR}22),以及 7766(它们的 XOR\mathsf{XOR}11),从而得到字典序最小的数组。

由 ChatGPT 4.1 翻译

来源

Codeforces 1971G,英文题名 XOUR。