首页 > 其他分享 >从缩点到圆方树

从缩点到圆方树

时间:2023-03-17 11:36:10浏览次数:36  
标签:缩点 连通 无向 割点 圆方树 low dfn 分量

一些概念

连通:无向图中的任意两点都可以互相到达。

强连通:有向图中的任意两点都可以互相到达。

连通分量:无向图的极大连通子图。

强连通分量:有向图的极大强连通子图。


DFS 生成树:对一张图进行深度优先遍历得到的生成树。

树边:在 DFS 生成树上的边。

前向边:由子树的根连向子树内的非树边。

返祖边:由结点连向其祖先的边。

横叉边:除上面三种以外的边。


割点:无向连通图删除某个点和以其为端点的所有边后,若图不再连通,则该点是图的一个割点。

割边(桥):无向连通图删除某条边后,若图不再连通,则该边是图的一条割边。

点双连通图:不存在割点的无向连通图。

边双连通图:不存在割边的无向连通图。

点双连通分量:无向连通图的极大点双连通子图。

边双连通分量:无向连通图的极大边双连通子图。

缩点(求强连通分量)

对于点 \(u\),记录两个信息 \(dfn_u\) 和 \(low_u\)。

\(dfn_u\) 表示时间戳,即点 \(u\) 是第几个被遍历到的。

\(low_u\) 表示从点 \(u\) 开始,经过的边的两个端点均处于未找出的强连通分量中,所能到达的最小时间戳。

在 DFS 的过程中,将经过的点塞进一个栈里面。递归完后一旦发现 \(dfn_u=low_u\) 就说明 \(u\) 无法离开以其为根的子树。此时一直弹栈直至弹出点 \(u\),弹出的这些点就构成了一个强连通分量。

考虑如何求出 \(low_u\),枚举 \(u\) 的每条出边 \((u,v)\):

  • 点 \(v\) 未遍历过,先递归处理该点,这样 \((u,v)\) 就成了树边,令 \(low_u\gets\min\{low_u,low_v\}\)。
  • 点 \(v\) 已遍历过:
    • 点 \(v\) 处于一个已找出的强连通分量中,显然它并不能帮我们走出去,直接跳过。
    • 点 \(v\) 处于未找出的强连通分量中,这样 \((u,v)\) 就成了非树边,同样令 \(low_u\gets\min\{low_u,low_v\}\)。需要注意的是,\(v\) 一定能走到两点的 LCA 处,从而一定能走到 \(u\)。

但存在一个问题,\(low\) 有时会不能更新完全,例如下图。

按照 \(1\to 2\to 3\) 的顺序走,假设先遍历了绿色边,再遍历了红色边,可以发现原因是 \(low_2\) 没有更新完全时就去递归处理了 \(3\) 号点,进而导致 \(low_3\) 也不能更新完全。

这个问题显然是不能避免的,所幸这并不会影响 \(dfn_{low_u}\) 与 \(dfn_u\) 的相对大小。

割点

可以发现无向图不存在横叉边,返祖边由树边和前向边组成。

随便钦定一个根结点,如果存在两棵及以上的子树说明它是割点。

\(dfn\) 定义不变,\(low\) 的定义改成最多经过一条非树边或反向经过一条树边所能到达的最小时间戳。

如果存在边 \((u,v)\) 其中 \(u\) 是 \(v\) 的父亲满足 \(dfn_u=low_v\) 则说明以 \(v\) 为根的子树中的点如果不通过 \(u\) 就与外界不连通了,即 \(u\) 为一个割点。

需要注意的是,删除一个点的同时会删掉以其为端点的所有边,所以 \(low\) 必须按照定义来,如果和强连通分量一样可能会导致中途经过割点。

割边

\(low\) 的定义和割点稍有不同,不能反向经过树边(当然割点你也可以这么写)。

非树边不可能是割边。如果树边 \((u,v)\) 其中 \(u\) 是 \(v\) 的父亲满足 \(low_u>dfn_u\) 则说明以 \(v\) 为根的子树中的点如果不通过 \((v,u)\) 就与外界不连通了。

需要注意的是反向经过一条树边的处理,当出现重边时需要特判一下。

点双连通分量

每次删除割点,分成若干个不连通的子图,然后将割点重新加入每个子图。如果找不到割点就说明已经是点双连通分量了。

当然肯定不用直接这么写,在搜索过程中用栈维护即可。

边双连通分量

找出所有的割边标记为不能经过,剩下的连通块就是所有的边双连通分量。

圆方树

原图中每个点双都对应一个方点,每个点都对应一个圆点,每个方点向其点双中的点对应的圆点连边。

形态就是若干个菊花图通过割点连在一起。

标签:缩点,连通,无向,割点,圆方树,low,dfn,分量
From: https://www.cnblogs.com/landsol/p/17226050.html

相关文章

  • CF1463E. Plan of Lectures(拓扑排序+缩点)——Educational Codeforces Round 100 (Rate
    目录题意思路代码参考题意条件1:给定一颗树,每个结点必须在父节点之后出现条件2:给定k个特殊点对u,v,u的下一个结点必须是v现在要求出满足上述两个条件结点序列(每个结点有......
  • 圆方树学习笔记
    圆方树学习笔记oiwiki模板voidtarjan(intu){ dfn[u]=low[u]=++ct;st[++tp]=u;tot++; for(intv:g[u]) if(!dfn[v]) { tarjan(v);low[u]=min(low[v],low......
  • 缩点-DAG 性质的应用:P2002,P1262,P2341,P1407,P2746(P2812)
    缩点不只用于转化图为DAG,还可以进一步发掘图的性质,从而将题目变成结论题所求信息转化到图上,方便建模。P2002https://www.luogu.com.cn/problem/P2002在一个强连通分量......
  • 缩点-将图转化为 DAG 跑 DP :P1455,P2169
    之前有提到,缩点可以将一张有向图转化为一张有向无环图(DAG),这样我们就可以在图上跑DP了。而我们实现DP的手段一般是在拓扑排序中实现,有时候也会用到最短路。P1455https......
  • 缩点学习笔记
    假如题目名称不是“【模板】缩点”的话,是否能想到缩点?这道题如何联想到缩点?首先题目给出的图,可能存在强连通分量,这样的强连通分量中,所有的点权都可全部取到,所以如果走到......
  • 缩点 P2812 校园网络【[USACO]Network of Schools加强版】
    首先找出图中的强连通分量,用tarjan算法。强连通分量内部强联通,所以将其看成一个点是不影响的。进行缩点之后,整张图变成了一个有向无环图。首先对于每一条边进行检测,如果......
  • 割点、桥、圆方树
    割点与桥定义对于一个无向图,如果将一个点及其相连的边去掉后连通块数量增加,这个点就是割点;如果去掉一个边后连通块数量增加,这条边就是桥,也称割边。求法对无向图的每个......
  • 圆方树学习笔记
    部分内容参照了OI-wiki定义对于这样的一个无向图,左侧的\({1,2,3}\)和右侧的\({3,4,5}\)分别构成一个点双联通分量。中间的\(3\)号节点就是一个割点。不难发现,点双......
  • P1073 [NOIP2009 提高组] 最优贸易 强联通分量+缩点
    //题意:给出有向图,有环(SCC),每个节点有一个商品值,小明想从1点走向n点,同时想要进行一次贸易,即从路线上某个点买入商品,又在某个节点卖出,询问最大收益是多少(如果收益为负数......
  • 圆方树
    OIwiki应该和这个差不多小粉兔blog例题CF1763FEdgeQueries题解↓这些题还没写,先留坑P4630[APIO2018]铁人两项CF487ETouristsP4606[SDOI2018]战略游戏P432......