CF2147B Multiple Construction
题目描述
给定一个整数 $n$。你的任务是构造一个长度为 $2 \cdot n$ 的数组,要求满足以下条件:
- $1$ 到 $n$ 每个整数在数组中恰好出现两次。
- 对于每个整数 $x$($1 \leq x \leq n$),$x$ 两次出现的位置之间的距离是 $x$ 的倍数。也就是说,若 $p_x$ 和 $q_x$ 分别是 $x$ 两次出现的位置下标,则 $| q_x - p_x |$ 必须能被 $x$ 整除。
可以证明,总是存在一种满足条件的方案。
输入格式
每个测试点包含多组测试数据。第一行包含一个整数 $t$($1 \leq t \leq 10^4$),表示测试数据组数。
接下来的 $t$ 行,每行包含一个整数 $n$($1 \leq n \leq 2 \cdot 10^{5}$)。
保证所有测试数据中 $n$ 的和不超过 $2 \cdot 10^{5}$。
输出格式
对于每组测试数据,输出一行 $2 \cdot n$ 个整数,表示满足条件的数组。
如存在多种合法方案,输出任意一种均可。
说明/提示
[可视化工具链接](https://codeforces.com/assets/contests/2147/B_RlbLXHyL5DuDqDlx4DG1.html)
在第一个测试样例中:
- 数字 $1$ 出现在第 $1$ 和第 $3$ 个位置:两次出现的距离为 $2$,是 $1$ 的倍数。
- 数字 $2$ 出现在第 $2$ 和第 $4$ 个位置:两次出现的距离为 $2$,是 $2$ 的倍数。
在第二个测试样例中:
- 数字 $1$ 出现在第 $1$ 和第 $3$ 个位置:距离为 $2$,是 $1$ 的倍数。
- 数字 $2$ 出现在第 $4$ 和第 $6$ 个位置:距离为 $2$,是 $2$ 的倍数。
- 数字 $3$ 出现在第 $2$ 和第 $5$ 个位置:距离为 $3$,是 $3$ 的倍数。
在第三个测试样例中,数字 $1$ 两次出现位置是在第 $1$ 和第 $2$,距离为 $1$,是 $1$ 的倍数。
由 ChatGPT 5 翻译