AT_abc132_e [ABC132E] Hopscotch Addict
题目描述
Ken 君非常喜欢玩“けんけんぱ”。今天,他决定在一个有向图 $G$ 上玩这个游戏。$G$ 由 $N$ 个编号为 $1$ 到 $N$ 的顶点和 $M$ 条边组成,第 $i$ 条边连接顶点 $u_i$ 和顶点 $v_i$。
Ken 君一开始站在顶点 $S$,他想通过“けんけんぱ”移动到顶点 $T$。一次“けんけんぱ”操作指的是:连续进行 $3$ 次“从当前所在顶点选择一条出边,移动到该边所连接的顶点”的操作。
请你判断 Ken 君是否能够从顶点 $S$ 移动到顶点 $T$,如果可以,请输出最少需要多少次“けんけんぱ”操作。如果在一次“けんけんぱ”操作的中途经过顶点 $T$,也不算到达顶点 $T$,只有在完成一次完整的“けんけんぱ”操作后停在顶点 $T$,才算到达。
输入格式
输入按以下格式从标准输入读入。
> $N$ $M$
> $u_1$ $v_1$
> $u_2$ $v_2$
> $\vdots$
> $u_M$ $v_M$
> $S$ $T$
输出格式
如果无论进行多少次“けんけんぱ”操作都无法从顶点 $S$ 移动到顶点 $T$,输出 $-1$。如果可以移动到,输出所需的最小“けんけんぱ”操作次数。
说明/提示
## 限制条件
- $2 \leq N \leq 10^5$
- $0 \leq M \leq \min(10^5, N(N-1))$
- $1 \leq u_i, v_i \leq N\ (1 \leq i \leq M)$
- $u_i \neq v_i\ (1 \leq i \leq M)$
- 如果 $i \neq j$,则 $(u_i, v_i) \neq (u_j, v_j)$
- $1 \leq S, T \leq N$
- $S \neq T$
## 样例解释 1
第一次“けんけんぱ”可以按 $1 \rightarrow 2 \rightarrow 3 \rightarrow 4$ 移动,第二次“けんけんぱ”可以按 $4 \rightarrow 1 \rightarrow 2 \rightarrow 3$ 移动,这样就能到达顶点 $3$,这是最少的次数。
## 样例解释 2
无论进行多少次“けんけんぱ”操作,都只能回到顶点 $1$,无法到达顶点 $2$。虽然在“けんけんぱ”操作的中途可能经过顶点 $2$,但这不算到达。
## 样例解释 3
顶点 $S$ 和顶点 $T$ 可能是不连通的。
由 ChatGPT 4.1 翻译