//无向图的割点和桥:
//cutnode[u]=true表示u是一个割点
//cutedge(u,v)=true表示(u,v)是一条割边
//Color[u]: 黑 访问完毕 灰 正在访问 白 未访问;
Tarjan(u,father){
DFN[u]=LOW[u]=++time;
//LOW[u]: u以及u的子孙所能到达的最小时间戳
Color[u]=灰;
put u into a stack; //入栈
for each e=(u,v)
if (color[v]==白){
Tarjan(v,u);
LOW[u]=min(LOW[u],LOW[v]);
//若存在边(u,v),且DFN[u]<LOW[v],则(u,v)为一条割边
if (DFN[u]<LOW[v]) cutedge(u,v)=true;
//若存在边(u,v),且DFN[u]<=LOW[v],则u为一个割点;
//当u为根,且至少有2棵子树
//用son[u]记录u的儿子个数,当color[v]=白说明多一个儿子;
son[u]++;
if ((u==root && son[u]>1) || (u!=root && DFN[u]<=LOW[v]))
cutnode[u]=true;
} else
if (v!=father)
LOW[u]=min(LOW[u],DFN[v]);
Color[u]=黑;
//图中一些概念:
//点连通度: 最小割点集合中的点数
//边连通度: 最小割边集合中的边数
//双连通分支: 可理解为任意两点之间有两条路径的极大的子图
//如果一个无向连通图的点/边连通度大于1,则称该图是点/边双连通的;
//当访问结束回退时,若LOW[u]=DFN[u],则有一个双连通分支;
if (LOW[u]==DFN[u]) pop until u;
//弹出元素属于同一个双连通分支;
//双连通分支缩点后会变成一棵树
}
//有向图的强连通分量(分支):
//强连通: 有向图中两个点之间至少有1条路径
//强连通分量: 极大强连通子图;
//与无向图的双连通分支求法一致;
//强连通分支会形成DAG(有向无环图)
//考虑以下问题:
//假设有一个无向图
//求解最小加几条边,使得不存在桥
//缩点后形成了一棵树
//这棵树中度数为1的结点个数为x
//答案就是(x+1)/2
//考虑消除所有度为1的结点即可,连边可以增加它们的度数;
//假设有一个有向图
//求解最小加几条边,使得整张图强连通
//首先求强连通分量缩点
//然后在新的缩点的图中
//求出入度为0点的个数为a,出度为0的点的个数为b
//答案就是max{a,b}
//想法也是简单的,尽量产生环;
图论: 割点、桥(割边)、强连通分量 学习笔记
原创
©著作权归作者所有:来自51CTO博客作者myzhy的原创作品,请联系作者获取转载授权,否则将追究法律责任
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
HarmonyOS NEXT 学习笔记
鸿蒙os 页面一键置灰
页面效果 API -
小结:双连通分量 & 强连通分量 & 割点 & 割边
概要:各种dfs时间戳。。全是tarjan(或加上他的小伙伴)无限膜拜tarja
OI Tarjan 小结 割点 双连通分量 -
【图论算法及模版】割点,割边,强联通分量,点双联通分量,边双联通分量
[原]【图
图论 割点 强连通分量 连通图 -
无向图的割点,桥,双连通分量,有向图的强连通分量总结
一、无向图的割点,桥,双连通分量
图的连通性 双连通分量 无向图 强连通分量 -
POJ 1523 SPF(割点所割连通分量数)
#include <cstring>#include <
#include 结点 割点 -
POJ 1523 SPF (割点,连通分量)
题意:给出一个网络(不一定连通),求所有的割点,以及割点可以切分
连通分量 割点 #include 子节点 i++ -
opencv 轮廓坐标上下限
使用C++、opencv计算轮廓的周长、面积、圆形度、周径比等特征参数图像的特征参数用于图像的模式识别(图像识别),获取越多种类的特征参数,可从中选择合适的进行组合,进而更好地区分各个物体。之前介绍过获取图像的灰度共生矩阵()、不变矩()、傅立叶描述子()等,此次根据物体的轮廓进而计算出轮廓的周长、面积、圆形度、周径比等特征参数。还可自行拓展,如物体面积与最小外接矩形面积比、与最小外接圆的面积比、
opencv 轮廓坐标上下限 图像特征参数 minAreaRect minEnclosingCircle 圆形度