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