CF2180C XOR-factorization
题目描述
Ostad 认为通常的因数分解方式过于数学化,因此他发明了一种被称为“异或因数分解”的新概念,更加偏向计算机科学。对于给定的整数 $n$,一组整数序列 $a_1, a_2, \ldots, a_k$,其中 $0 \le a_i \le n$ 对于所有 $i$,被称为 $n$ 的异或因数分解,当且仅当
$$
a_1 \oplus a_2 \oplus \cdots \oplus a_k = n,
$$
其中 $\oplus$ 表示[按位异或运算](https://en.wikipedia.org/wiki/Bitwise_operation#XOR)。
给定整数 $n$ 和 $k$,请找到一组 $n$ 的异或因数分解 $a_1, a_2, \ldots, a_k$,使得 $a_1 + a_2 + \cdots + a_k$ 的和最大。
可以证明,在题目给定的条件下,总能找到异或因数分解。
输入格式
每组测试包含多个测试用例。第一行包含测试用例个数 $t$($1 \le t \le 10^4$)。接下来每行包含两个整数 $n$ 和 $k$($1 \le n \le 10^9$,$1 \le k \le 10^5$)。
保证所有测试用例中 $k$ 的总和不超过 $10^5$。
输出格式
对于每个测试用例,输出 $k$ 个整数 $a_1, a_2, \ldots, a_k$,满足 $0 \le a_i \le n$。
可以证明,答案一定存在。如果有多组合法答案,你可以按任意顺序输出其中一组。
说明/提示
在第一个测试用例中,我们可以将 $5$ 分解为 $1 \oplus 4 \oplus 5 \oplus 5$,此时和为 $15$,可以证明不存在使异或和为 $5$ 且总和更大的分解方式。
在第二个测试用例中,我们可以将 $4$ 分解为 $4 \oplus 4 \oplus 4$,总和为 $12$,这显然是可能的最大值。
由 ChatGPT 5 翻译