#1963. [noi省选联考 2021 A/B 卷] 图函数

[noi省选联考 2021 A/B 卷] 图函数

题目描述

对于一张 $n$ 个点 $m$ 条边的有向图 $G$(顶点从 $1 \sim n$ 编号),定义函数 $f(u, G)$:
  1. 初始化返回值 cnt=0cnt = 0,图 G=G G'= G
  2. 11nn 按顺序枚举顶点 vv,如果当前的图 GG' 中,从 uuvv 与从 vvuu 的路径都存在,则将 cnt+1cnt + 1,并在图 GG' 中删去顶点 vv 以及与它相关的边。
  3. 22 步结束后,返回值 cntcnt 即为函数值。

现在给定一张有向图 GG,请你求出 h(G)=f(1,G)+f(2,G)++f(n,G)h(G) = f(1, G) + f(2, G) + \cdots + f(n, G) 的值。

更进一步地,记删除(按输入顺序给出的)第 11ii 条边后的图为 GiG_i1im1 \le i \le m),请你求出所有 h(Gi)h(G_i) 的值。

</p>

输入输出格式

输入格式


第一行,两个整数 $n,m$,表示图的点数与边数。 接下来 $m$ 行,每行两个整数,第 $i$ 行的两个整数 $x_i, y_i$ 表示一条有向边 $x_i \to y_i$。

数据保证 xiyix_i \neq y_i 且同一条边不会给出多次。

</p>

输出格式


输出一行 $m + 1$ 个整数,其中第一个数表示给出的完整图 $G$ 的 $h(G)$ 值。第 $i$($2 \le i \le m + 1$)个整数表示 $h(G_{i-1})$。

输入输出样例

输入样例 #1

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

输出样例 #1

6 5 5 4 4 4 4

输入样例 #2

见附件中的 graph/graph2.in。

输出样例 #2

见附件中的 graph/graph2.ans。

说明

【样例 #1 解释】

对于给出的完整图 GG

  1. f(1,G)=1f(1, G) = 1,过程中删除了顶点 11
  2. f(2,G)=1f(2, G) = 1,过程中删除了顶点 22
  3. f(3,G)=2f(3, G) = 2,过程中删除了顶点 2,32, 3
  4. f(4,G)=2f(4, G) = 2,过程中删除了顶点 1,41, 4

【数据范围】

对于所有测试数据:2n1032 \le n \le {10}^31m2×1051 \le m \le 2 \times {10}^51xi,yin1 \le x_i, y_i \le n

每个测试点的具体限制见下表:

测试点编号 nn \le mm\le
141 \sim 4 1010
5115 \sim 11 100100 2×1032 \times {10}^3
122012 \sim 20 103{10}^3 5×1035 \times {10}^3
212521 \sim 25 2×1052 \times {10}^5