作者:黄雅萱介芳 | 来源:互联网 | 2023-10-12 10:40
之前一直对tarjan算法的这几种不同应用比较混淆我太弱啦!被BLO暴虐滚过来用tarjan求点双,很多神犇都给出了比较详细的解释和证明,在这里就不讲了(其实是这只蒟蒻根本不会orz)这里放一下
之前一直对tarjan算法的这几种不同应用比较混淆...我太弱啦!
被BLO暴虐滚过来
用tarjan求点双,很多神犇都给出了比较详细的解释和证明,在这里就不讲了(其实是这只蒟蒻根本不会orz)
这里放一下定义
这篇博客主要讲一讲求割点,点双的板子实现以及详细解释
先yy这样一道题:
有n个点,m条边,保证给出的是一个联通图,求割点
(真·最裸割点)
这道题就可以用下面这份代码实现
#pragma GCC optimize("O2")
#include
#include
#include
#include
#include
#include
#include
#include
#include
例如我们输入
5 5
1 2
2 3
1 3
3 4
4 5
程序完美の输出了 3,4
是不是很棒啊x
那么我们要统计点双的数量要怎么处理呢?
显然能发现,我们求出一个割点之后,被割点分成的几部分都能分别与这个割点组成一个点双
那么我们只需要统计每个割点被访问次数即可
更改之后的代码:
#pragma GCC optimize("O2")
#include
#include
#include
#include
#include
#include
#include
#include
#include
输出就是直接
当然对他做一点小小的改动也可以实现求桥..
只需要对于每次记录iscut 改为记录二维数组cutedge[x][v]即可
需要注意的是 这里的条件不同于求割点的小于等于 这里需要low[v]严格大于dfn[x]