atcoder#ABC241F. [ABC241F] Skate
[ABC241F] Skate
题目描述
行 列のグリッド型のスケート場があります。上から 行目、左から 行目のマスを で表します。
スケート場には 個の障害物があり、 個目の障害物は に置かれています。
高橋君は 回の移動において、上下左右いずれかの方向を選んで、障害物に当たるまで進み続けます。
障害物に当たるとその つ手前のマスで停止します。 なお、スケート場の周りは崖になっており、障害物に当たらないような移動は禁止とします。
高橋君ははじめ にいて、何回か移動することで で停止したいと考えています。
へ辿り着くには最小で何回の移動が必要ですか?辿り着けないときはその旨を伝えてください。
输入格式
入力は以下の形式で標準入力から与えられる。
输出格式
へ辿り着くには最小で何回の移動が必要か出力せよ。
ただし、辿り着けないならば -1
と出力せよ。
题目大意
有一个溜冰场,由 个横行和 个纵列的网格表示。 表示从上往下第 i 行和从 左往右第 列的方格。 溜冰场上有 个障碍物。第 个障碍物位于 处。 在一次移动中,小高可以从上、下、左、右四个方向中选择一个,一直移动到碰到障碍 物为止。由于溜冰场四周都是悬崖峭壁,因此禁止他开始一个永远不会碰到障碍物的移动。 小高最初在 处,他想停在 处。找出移动到 的最少移动次数,如果不 可能,请输出 。
This translation comes from highkj
7 8 7
3 4
5 6
1 4
2 1
2 8
4 5
5 7
6 2
6 6
4
4 6 2
3 2
3 5
4 5
2 5
-1
1 10 1
1 5
1 1
1 7
-1
提示
制約
- ならば、
- 入力は全て整数である
Sample Explanation 1
![](https://img.atcoder.jp/ghi/c376ca3813eb4c947eb605dea2d30454.png) 図は、 を S
で、 を G
で表しています。 $ (3,4)\rightarrow(2,4)\ \rightarrow(2,2)\ \rightarrow(5,2)\ \rightarrow(5,6) $ と移動すると、 回の移動で に辿り着くことができます。
Sample Explanation 2
![](https://img.atcoder.jp/ghi/07ab8a3e7c94525cd52704dd43e43b87.png) で停止する必要があります。 通過しただけでは へ辿り着いたとみなされないことに注意してください。
Sample Explanation 3
![](https://img.atcoder.jp/ghi/a423524262f4a075b94e2ab5f9e61164.png) 左を選んで進むと、高橋君は を通過したのちに崖に落ちてしまいます。 スケート場の周りは崖になっており、障害物に当たらないような移動は禁止されていることに注意してください。