loj#P3013. 「JOI 2019 Final」硬币收藏
「JOI 2019 Final」硬币收藏
题目描述
译自 JOI 2019 Final T4「コイン集め / Coin Collecting」
JOI 先生的收藏室里有一张巨大的桌子,上面有许多稀有的硬币。为了清理桌子,他要重新摆放硬币。
桌面可视为 的网格。网格上往下数第 行(),左往右数第 列()的格子坐标记为 。
JOI 先生有 枚硬币。初始时,第 枚 硬币被放在坐标为 的格子里。JOI 先生的目标是在每个满足 的格子 上恰好放一枚硬币。为了不损坏硬币,他能做的唯一一个操作是钦定一枚硬币然后将其移动到相邻的一个格子中(我们说两个格子相邻,当且仅当这两个格子有公共边)。在移动硬币的过程中,允许两个硬币处在同一个格子中。JOI 先生希望通过尽量少的操作次数完成目标。
现在给出硬币的数量和初始时所在的位置,编写一个程序,计算完成 JOI 先生目标所需的最少操作次数。
输入格式
从标准输入中读取数据。
第一行一个整数 。
接下来 行,第 行为两个整数 和 。
输出格式
输出数据到标准输出中。
输出一行一个整数,表示完成目标所需的最少操作次数。
3
0 0
0 4
4 0
2 1
2 5
-1 1
15
4
2 1
2 1
2 1
3 1
3 1
3 1
3 1
3 1
9
5
1000000000 1000000000
-1000000000 1000000000
-1000000000 -1000000000
1000000000 -1000000000
-1 -5
-2 2
2 8
4 7
-2 5
7 3
8000000029
数据范围与提示
Subtask # | 分值 | |
---|---|---|
1 | 8 | |
2 | 29 | |
3 | 63 |
对于所有输入数据,有 。