CF2179G Blackslex and Penguin Migration
题目描述
[IOI 2025 - Migrations](https://oj.uz/problem/view/IOI25_migrations)
本题为交互题。
Blackslex 正在研究的一种企鹅居住在一个 $n$ 行 $n$ 列的岛屿网格上。每个格子里恰好有一只企鹅。
他把每只企鹅编号为 $1$ 到 $n^2$。经过一段时间后,有些企鹅迁移到了其他格子。迁移之后,仍然每只企鹅会在某个格子里,并且每个格子都有且仅有一只企鹅。他现在需要获得每只企鹅的当前位置。
为此,他可以向一只企鹅询问与另一只企鹅的距离。
具体来说,设 $x$ 为某种企鹅在网格中的位置方案,$\operatorname{dist}(x, i, j)$ 表示企鹅 $i$ 与企鹅 $j$ 在 $x$ 网格中的曼哈顿距离 $^{\ast}$。
现在有一个隐藏的网格 $a$,包含 $n$ 行 $n$ 列。你需要找出一个网格 $b$,满足以下条件:
- $b$ 是 $n$ 行 $n$ 列的网格。
- 每个格子填入 $1$ 到 $n^2$ 之间的整数,每个编号只出现一次。
- 对所有 $1 \leq i, j \leq n^2$,都有 $\operatorname{dist}(a, i, j) = \operatorname{dist}(b, i, j)$。
你可以进行不超过 $3n^2+150$ 次如下操作:
- 给定 $i$,$j$($1 \leq i, j \leq n^2$),获得 $\operatorname{dist}(a, i, j)$ 的值。
$^{\ast}$ 设 $r_i$,$c_i$ 分别为企鹅 $i$ 所在的行列位置,同理 $r_j$,$c_j$ 表示企鹅 $j$ 的行列,则曼哈顿距离为 $|r_i-r_j|+|c_i-c_j|$。
输入格式
每个测试点包含多组测试数据。第一行包含整数 $t$($1 \leq t \leq 200$)——测试数据的组数。
每组数据的第一行包含一个整数 $n$($2 \leq n \leq 100$)——岛屿的边长。
保证所有测试数据的 $n$ 之和不超过 $500$。
输出格式
(本题为交互题,无固定输出格式。参见原题交互协议实现。)
说明/提示
注意附加的换行仅供易读,实际输出中不应输出这些内容。
在第一个测试用例中,隐藏网格 $a$ 是
1423
在第二个测试用例中,隐藏网格 $a$ 是
913427856
交互过程示例如下:
Contestant Judge Description
2 // 第一组数据开始,岛屿大小为 $n=2$
? 1 2 // 选手查询企鹅1和2的距离
1 // 企鹅1和2的距离为1
? 1 3
2
? 1 4
1
? 2 3
1
? 2 4
2
? 3 4
1
! // 选手确定了一个可能的网格 $b$
3 4
注意,所提交的网格不需要与隐藏网格完全一致,但需满足对所有 $1 \leq i, j \leq n^2$,都有 $\operatorname{dist}(a, i, j) = \operatorname{dist}(b, i, j)$。
2 // 第二组数据开始,岛屿大小为 $n=3$
? 1 8 // 选手查询企鹅1和8的距离
3
!
9 1 3
4 2 7
8 5 6
由 ChatGPT 5 翻译