图联通性问题,Tarjan)整理

技术图联通性问题,Tarjan)整理 图联通性问题(Tarjan)整理笑死,根本学不会笑死,根本学不会。(烂尾力
Tarjan算法是用于处理图连通性相关的一类算法。
1、强连通分量、双连通分量、割点与桥

图连通的塔尔詹问题的安排

笑,你根本学不会。

笑,你根本学不会。(无穷尾力)

Tarjan算法是一种用于处理图连通性的算法。

1、强连通分量、双连通分量、割点与桥的定义

参见OI维基

2、Tarjan算法的基本思想与框架

本质上,这些与连通性相关的量是通过构造dfs生成树,然后处理非树边而获得的。

dfs生成树的标记是通过dfn顺序(dfs是从某一点按顺序构造的),需要一个低值来处理非树边(看子树的树边或者最多看子树的一个非树边就可以到达dfn值最小的点)。

void tarjan(int x)

{

low[x]=dfn[x]=num;

for(int I=H[x];我;i=K[i])

{

int y=V[I];

if(!dfn[y])

tarjan(y,I),低[x]=min(低[x],低[y]);

其他

low[x]=min(low[x],dfn[y]);

}

}

3、强连通分量

非树边缘有三种:后边缘、交叉边缘和前边缘。

正面对答案没有贡献,不讨论。

边必须有贡献,并且满足低值的条件,并且更新到低。

只有当交叉边指向祖先可以返回dfs树的点时,它才能有所贡献。

综上所述,我们可以用一个栈记录一些节点,这些节点要么是当前点的祖先,要么可以到达祖先。

每个dfs到达时,节点都被放入堆栈。

不在堆栈中的节点不能更新低值,因为这些点不能返回祖先,也不能贡献。

当有一个点\(dfn(x)=low(x)\)时,意味着根为x的子树构成强连通分量,从这个点不能到达祖先节点,所以x及其上面的节点不堆叠,算作强连通分量。

void tarjan(int x)

{

low[x]=dfn[x]=num;

st[ top]=x,ins[x]=1;

for(int I=H[x];我;i=K[i])

{

int y=V[I];

if(!dfn[y])

tarjan(y),低[x]=min(低[x],低[y]);

否则如果(ins[y])

low[x]=min(low[x],dfn[y]);

}

if(dfn[x]==低[x])

{

碳纳米管;

for(;st[top]!=x;)

{

bl[st[top]]=cnt,a2[CNT]=a[ST[top]];

ins[st[top]]=0,-top;

}

bl[x]=cnt,a2[CNT]=a[x];

ins[x]=0,-top;

}

}

//在main中

for(int x=1;x=n;十)

if(!dfn[x])tar Jan(x);

4、桥与边双连通分量

\(dfn(x)低(y)\)

void tarjan(int x,int in_e)

{

low[x]=dfn[x]=num;

for(int I=H[x];我;i=K[i])

{

int y=V[I];

if(!dfn[y])

{

tarjan(y,I),低[x]=min(低[x],低[y]);

if(低[y]dfn[x])

{

int u=v[i],v=v[i^1];

if(uv)交换(u,v);

bdg.push_back(mkp(u,v));

}

}

否则如果(我!=(in_e^1)

low[x]=min(low[x],dfn[y]);

}

}

//在main中

for(int x=1;x=n;十)

if(!dfn[x]) tarjan(x,-1);

5、割点与点双连通分量

\(dfn(x) \leq low(y)\)

请注意,根节点需要两个满足条件的\(y\)。

void tarjan(int x,int rt)

{

low[x]=dfn[x]=num;

int标志=0;

for(int I=H[x];我;i=K[i])

{

int y=V[I];

if(!dfn[y])

{

tarjan(y,rt),低[x]=min(低[x],低[y]);

if(低[y]=dfn[x])

{

旗帜;

if(x!=rt | | flag 1)cut[x]=1;

}

}

其他

low[x]=min(low[x],dfn[y]);

}

}

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/107443.html

(0)

相关推荐

  • 怎么用Python在520俘获女神芳心

    技术怎么用Python在520俘获女神芳心这篇文章主要讲解了“怎么用Python在520俘获女神芳心”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用Python在52

    攻略 2021年11月2日
  • 物距是什么,物距和焦距的关系是什么

    技术物距是什么,物距和焦距的关系是什么物距物距是什么:u像距:v焦距:f关系:1/u+1/v=1/f光学中最基本的高斯成像公式:1/u+1/v=1/f,即物距的倒数加上像距的倒数等于焦距的倒数。其次,请你明白物像之间的因

    生活 2021年10月20日
  • 怎么使用Web3.js API 在页面中进行转账

    技术怎么使用Web3.js API 在页面中进行转账这期内容当中小编将会给大家带来有关怎么使用Web3.js API 在页面中进行转账,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。如何

    攻略 2021年11月2日
  • 描写女子美貌的句子,形容女子气质智慧美貌的句子

    技术描写女子美貌的句子,形容女子气质智慧美貌的句子1、都说喜欢穿裙子的女人是很浪漫的描写女子美貌的句子,骨子里都是妩媚的,是温婉如水的。我不知道,我只知道我穿裙子是比穿裤子美丽的。只要是美丽,我就会喜欢。MM们,让我们的

    生活 2021年10月19日
  • 怎么解决mysql的报错[ERROR] Native table 'performance_schema'问题

    技术怎么解决mysql的报错[ERROR] Native table performance_schema问题本篇内容主要讲解“怎么解决mysql的报错[ERROR] Native table performance_s

    攻略 2021年11月19日
  • 吃甘蔗的好处,听说吃甘蔗能洁牙

    技术吃甘蔗的好处,听说吃甘蔗能洁牙甘蔗味甘性寒吃甘蔗的好处,甘可滋补养血,寒可清热生津,故有滋养润燥之功效,那么甘蔗吃多了对牙齿好不好呢?下面就一起来看看吧
    1吃甘蔗对牙齿好吗
    吃甘蔗可以清洁牙齿,因此对牙齿有好处。甘蔗

    生活 2021年10月26日