#aBC319G. [ABC319G] Counting Shortest Paths

[ABC319G] Counting Shortest Paths

AT_abc319_g [ABC319G] Counting Shortest Paths

题目描述

对于一个有 NN 个顶点的无向完全图 GG,进行如下操作:

对于每个 i=1,2,,Mi = 1, 2, \ldots, M,删除连接顶点 uiu_i 和顶点 viv_i 的无向边。

在操作后的 GG 中,判断是否存在从顶点 11 到顶点 NN 的路径。如果存在,请求出从顶点 11 到顶点 NN 的最短路径的个数,并对 998244353998244353 取模。

这里,从顶点 11 到顶点 NN 的最短路径是指所有从顶点 11 到顶点 NN 的路径中,所经过的边数最少的路径。

输入格式

输入以如下格式从标准输入读入。

NN MM
u1u_1 v1v_1
u2u_2 v2v_2
\vdots
uMu_M vMv_M

输出格式

如果操作后的 GG 中不存在从顶点 11 到顶点 NN 的路径,则输出 -1。如果存在,则输出从顶点 11 到顶点 NN 的最短路径的个数,对 998244353998244353 取模。

输入输出样例 #1

输入 #1

6 7
4 3
1 3
2 4
1 6
4 6
5 1
6 2

输出 #1

3

输入输出样例 #2

输入 #2

4 6
1 2
1 3
1 4
2 3
2 4
3 4

输出 #2

-1

说明/提示

限制条件

  • 2N2×1052 \leq N \leq 2 \times 10^5
  • $0 \leq M \leq \min\lbrace 2 \times 10^5, N(N-1)/2 \rbrace$
  • 1ui,viN1 \leq u_i, v_i \leq N
  • uiviu_i \neq v_i
  • $i \neq j \implies \lbrace u_i, v_i \rbrace \neq \lbrace u_j, v_j \rbrace$
  • 所有输入均为整数

样例解释 1

操作后的 GG 中,从顶点 11 到顶点 NN 的最短路径包含 33 条边,共有如下 33 条路径:

  • 顶点 11 \rightarrow 顶点 22 \rightarrow 顶点 33 \rightarrow 顶点 66
  • 顶点 11 \rightarrow 顶点 22 \rightarrow 顶点 55 \rightarrow 顶点 66
  • 顶点 11 \rightarrow 顶点 44 \rightarrow 顶点 55 \rightarrow 顶点 66

样例解释 2

操作后的 GG 中没有任何边,因此不存在从顶点 11 到顶点 NN 的路径,输出 -1

由 ChatGPT 4.1 翻译