100 atcoder#ABC132E. [ABC132E] Hopscotch Addict

[ABC132E] Hopscotch Addict

题目描述

ケンくんはけんけんぱが大好きです。今日は有向グラフ G G の上でけんけんぱをすることにしました。 G G 1 1 から N N で番号付けされた N N 頂点および M M 辺からなり、 i i 番目の辺は頂点 ui u_i から頂点 vi v_i に接続しています。

ケンくんははじめ頂点 S S にいて、頂点 T T までけんけんぱで移動したいです。 1 1 回のけんけんぱでは、「自分の今いる頂点から出ている辺を 1 1 つ選んで、その辺が接続する頂点に移動する」という操作をちょうど 3 3 回連続で行います。

ケンくんが頂点 T T に移動することができるか、また移動できるなら最小何回のけんけんぱで頂点 T T まで移動することができるかを答えてください。 けんけんぱの操作の途中で頂点 T T に訪れても、「頂点 T T に移動できた」とは見なさないことに注意してください。

输入格式

入力は以下の形式で標準入力から与えられる。

N N M M u1 u_1 v1 v_1 : : uM u_M vM v_M S S T T

输出格式

何回けんけんぱを繰り返しても頂点 S S から頂点 T T へ移動できない場合には、1 -1 を出力せよ。 移動できる場合には、移動するのに必要なけんけんぱの最小回数を出力せよ。

题目大意

给定一张 nn 个点 mm 条边的有向图,及起点 ss 与终点 tt。从 ss 出发,每次可以走恰好 33 步,问要走多少次 33 步,才能到达 tt。如果不能到达,输出 1-1

1n,m105,st1\le n,m\le10^5,s\ne t

没有重边自环

4 4
1 2
2 3
3 4
4 1
1 3
2
3 3
1 2
2 3
3 1
1 2
-1
2 0
1 2
-1
6 8
1 2
2 3
3 4
4 5
5 1
1 4
1 5
4 6
1 6
2

提示

制約

  • 2  N  105 2\ \leq\ N\ \leq\ 10^5
  • 0  M  min(105, N (N1)) 0\ \leq\ M\ \leq\ \min(10^5,\ N\ (N-1))
  • 1  ui, vi  N(1  i  M) 1\ \leq\ u_i,\ v_i\ \leq\ N(1\ \leq\ i\ \leq\ M)
  • ui  vi (1  i  M) u_i\ \neq\ v_i\ (1\ \leq\ i\ \leq\ M)
  • i  j i\ \neq\ j ならば (ui, vi)  (uj, vj) (u_i,\ v_i)\ \neq\ (u_j,\ v_j)
  • 1  S, T  N 1\ \leq\ S,\ T\ \leq\ N
  • S  T S\ \neq\ T

Sample Explanation 1

1 1 回目のけんけんぱでは $ 1\ \rightarrow\ 2\ \rightarrow\ 3\ \rightarrow\ 4 $、2 2 回目のけんけんぱでは $ 4\ \rightarrow\ 1\ \rightarrow\ 2\ \rightarrow\ 3 $ と移動することで頂点 3 3 に辿り着くことができ、これが最小回数です。

Sample Explanation 2

何回けんけんぱを繰り返しても頂点 1 1 に辿り着くため、頂点 2 2 に移動することは不可能です。 けんけんぱの途中で頂点 2 2 を通過することはできますが、これは移動できたとは見なしません。

Sample Explanation 3

頂点 S S と頂点 T T は非連結である場合があります。