题目描述:
如题, 在 n n n 个节点 m m m 条边的有向图中, 点数大于 1 1 1 的强连通分量个数。
题目分析:
这道题显然是缩点模板题, 极其适合练手。
这里介绍 Tarjan 的做法。
我们在图中考虑链, 我们考虑如果有环的话必然经过已经经过的点, 即在链上出现过的点。
所以我们可以考虑维护栈。
这样就可以构造出找到的点, 我们用 l o w low low 数组表示
最后我们就可以求出每个强联通分量的节点数。
代码如下:
#include<bits/stdc++.h>
using namespace std;
const int M = 5e4 + 10;
const int N = 1e4 + 10;
int n, m, head[N], cnt, sum[N], ans;
int dfn[N], low