日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Targan 算法[有向图强连通分量]

發(fā)布時(shí)間:2025/6/15 编程问答 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Targan 算法[有向图强连通分量] 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

[有向圖強(qiáng)連通分量]

在有向圖G中,如果兩個(gè)頂點(diǎn)間至少存在一條路徑,稱兩個(gè)頂點(diǎn)強(qiáng)連通(stronglyconnected)。如果有向圖G的每?jī)蓚€(gè)頂點(diǎn)都強(qiáng)連通,稱G是一個(gè)強(qiáng)連通圖。非強(qiáng)連通圖有向圖的極大強(qiáng)連通子圖,稱為強(qiáng)連通分量(strongly connected components)。

下圖中,子圖{1,2,3,4}為一個(gè)強(qiáng)連通分量,因?yàn)轫旤c(diǎn)1,2,3,4兩兩可達(dá)。{5},{6}也分別是兩個(gè)強(qiáng)連通分量。


直接根據(jù)定義,用雙向遍歷取交集的方法求強(qiáng)連通分量,時(shí)間復(fù)雜度為O(N^2+M)。更好的方法是Kosaraju算法或Tarjan算法,兩者的時(shí)間復(fù)雜度都是O(N+M)。本文介紹的是Tarjan算法。

[Tarjan算法]

Tarjan算法是基于對(duì)圖深度優(yōu)先搜索的算法,每個(gè)強(qiáng)連通分量為搜索樹中的一棵子樹。搜索時(shí),把當(dāng)前搜索樹中未處理的節(jié)點(diǎn)加入一個(gè)堆棧,回溯時(shí)可以判斷棧頂?shù)綏V械墓?jié)點(diǎn)是否為一個(gè)強(qiáng)連通分量。

定義DFN(u)為節(jié)點(diǎn)u搜索的次序編號(hào)(時(shí)間戳),Low(u)為u或u的子樹能夠追溯到的最早的棧中節(jié)點(diǎn)的次序號(hào)。由定義可以得出,

Low(u)=Min{DFN(u),Low(v),(u,v)為樹枝邊,u為v的父節(jié)點(diǎn)
??? ???????DFN(v),(u,v)為指向棧中節(jié)點(diǎn)的后向邊(非橫叉邊)}

當(dāng)DFN(u)=Low(u)時(shí),以u(píng)為根的搜索子樹上所有節(jié)點(diǎn)是一個(gè)強(qiáng)連通分量。

算法偽代碼如下

tarjan(u)
{
?DFN[u]=Low[u]=++Index??????? // 為節(jié)點(diǎn)u設(shè)定次序編號(hào)和Low初值
?Stack.push(u)??????????????? // 將節(jié)點(diǎn)u壓入棧中
?for each (u, v) in E???????? // 枚舉每一條邊
? if (v is not visted)??????? // 如果節(jié)點(diǎn)v未被訪問過
?? tarjan(v)????????????????? // 繼續(xù)向下找
?? Low[u] = min(Low[u], Low[v])
? else if (v in S)??????????? // 如果節(jié)點(diǎn)u還在棧內(nèi)
?? Low[u] = min(Low[u], DFN[v])
?if (DFN[u] == Low[u])??????? // 如果節(jié)點(diǎn)u是強(qiáng)連通分量的根
? repeat
?? v = S.pop??????????? ?????// 將v退棧,為該強(qiáng)連通分量中一個(gè)頂點(diǎn)
?? print v
? until (u== v)
}

接下來是對(duì)算法流程的演示。

從節(jié)點(diǎn)1開始DFS,把遍歷到的節(jié)點(diǎn)加入棧中。搜索到節(jié)點(diǎn)u=6時(shí),DFN[6]=LOW[6],找到了一個(gè)強(qiáng)連通分量。退棧到u=v為止,{6}為一個(gè)強(qiáng)連通分量。


返回節(jié)點(diǎn)5,發(fā)現(xiàn)DFN[5]=LOW[5],退棧后{5}為一個(gè)強(qiáng)連通分量。


返回節(jié)點(diǎn)3,繼續(xù)搜索到節(jié)點(diǎn)4,把4加入堆棧。發(fā)現(xiàn)節(jié)點(diǎn)4像節(jié)點(diǎn)1的后向邊,節(jié)點(diǎn)1還在棧中,所以LOW[4]=1。節(jié)點(diǎn)6已經(jīng)出棧,不再訪問6,返回3,(3,4)為樹枝邊,所以LOW[3]=LOW[4]=1。


繼續(xù)回到節(jié)點(diǎn)1,最后訪問節(jié)點(diǎn)2。訪問邊(2,4),4還在棧中,所以LOW[2]=4。返回1后,發(fā)現(xiàn)DFN[1]=LOW[1],把棧中節(jié)點(diǎn)全部取出,組成一個(gè)連通分量{1,3,4,2}。


至此,算法結(jié)束。經(jīng)過該算法,求出了圖中全部的三個(gè)強(qiáng)連通分量{1,3,4,2},{5},{6}。

可以發(fā)現(xiàn),運(yùn)行Tarjan算法的過程中,每個(gè)頂點(diǎn)都被訪問了一次,且只進(jìn)出了一次堆棧,每條邊也只被訪問了一次,所以該算法的時(shí)間復(fù)雜度為O(N+M)。

求有向圖的強(qiáng)連通分量還有一個(gè)強(qiáng)有力的算法,為Kosaraju算法。Kosaraju是基于對(duì)有向圖及其逆圖兩次DFS的方法,其時(shí)間復(fù)雜度也是 O(N+M)。與Trajan算法相比,Kosaraju算法可能會(huì)稍微更直觀一些。但是Tarjan只用對(duì)原圖進(jìn)行一次DFS,不用建立逆圖,更簡(jiǎn)潔。 在實(shí)際的測(cè)試中,Tarjan算法的運(yùn)行效率也比Kosaraju算法高30%左右。此外,該Tarjan算法與求無向圖的雙連通分量(割點(diǎn)、橋)的Tarjan算法也有著很深的聯(lián)系。學(xué)習(xí)該Tarjan算法,也有助于深入理解求雙連通分量的Tarjan算法,兩者可以類比、組合理解。

求有向圖的強(qiáng)連通分量的Tarjan算法是以其發(fā)明者Robert Tarjan命名的。Robert Tarjan還發(fā)明了求雙連通分量的Tarjan算法,以及求最近公共祖先的離線Tarjan算法,在此對(duì)Tarjan表示崇高的敬意。

void tarjan(int i)
{
?int j;
?DFN[i]=LOW[i]=++Dindex;
?instack[i]=true;
?Stap[++Stop]=i;
?for (edge *e=V[i];e;e=e->next)
?{
? j=e->t;
? if (!DFN[j])
? {
?? tarjan(j);
?? if (LOW[j]<LOW[i])
??? LOW[i]=LOW[j];
? }
? else if (instack[j] && DFN[j]<LOW[i])
?? LOW[i]=DFN[j];
?}
?if (DFN[i]==LOW[i])
?{
? Bcnt++;
? do
? {
?? j=Stap[Stop--];
?? instack[j]=false;
?? Belong[j]=Bcnt;
? }
? while (j!=i);
?}
}
void solve()
{
?int i;
?Stop=Bcnt=Dindex=0;
?memset(DFN,0,sizeof(DFN));
?for (i=1;i<=N;i++)
? if (!DFN[i])
?? tarjan(i);
}

總結(jié)

以上是生活随笔為你收集整理的Targan 算法[有向图强连通分量]的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 肥臀熟女一区二区三区 | 日韩xx视频 | 国产毛片电影 | aa级黄色片 | 亚洲国产成人精品久久 | 视频一区在线播放 | 日批在线观看视频 | 精品国偷自产一区二区三区 | 在线天堂www在线国语对白 | 国产3p露脸普通话对白 | 黄色动漫软件 | 国产精品久久久久久亚洲调教 | 韩国伦理中文字幕 | 女尊高h男高潮呻吟 | 亚洲性夜 | 91美女网| 久久久天堂国产精品女人 | 国产高清日韩 | 在线观看免费视频一区二区 | 撸大师av| 日本黄色a视频 | 三级色网站| 国产精品视频一二区 | 日韩中文字幕综合 | 日韩少妇内射免费播放 | 亚洲网站色 | 五十路妻| 国内精品毛片 | www.色黄| 欧美a√在线 | 天天看片天天操 | 婷婷色中文网 | 少妇一级1淫片 | 国产一级二级av | 欧美9999| 欧美一级做a爰片免费视频 成人激情在线观看 | 91亚洲网站 | 色婷婷综合久久久久中文字幕 | 九九爱视频 | 天天干天天干天天 | 国产中文字幕三区 | 亚洲国产精品麻豆 | 国产精品久久久国产盗摄 | 操三八男人的天堂 | 免费在线看污 | 日本熟妇一区二区三区四区 | 不卡欧美| 毛片看看 | 亚洲制服丝袜一区 | 国产精品无码网站 | 九九精品视频在线观看 | 性感美女高潮 | 午夜成人影片 | 亚洲九区 | 欧美一区二区在线播放 | 欧美日韩国产三区 | 亚洲天堂av网站 | 少妇被躁爽到高潮无码人狍大战 | av番号网 | 欧美一区二区视频在线 | 制服.丝袜.亚洲.中文.综合 | 色啦啦视频 | www.天天色 | 成人羞羞免费 | 天天精品综合 | 久久婷婷五月综合色吧 | 无码国产伦一区二区三区视频 | 亚洲爆爽 | 丝袜诱惑一区 | 夜夜艹天天干 | 黄色三级生活片 | 久久久久久久亚洲av无码 | 国产激情精品一区二区三区 | 亚洲第一视频在线 | 久久国产精品电影 | 1024国产视频| 天天做夜夜爽 | 天天艹夜夜 | 探花一区| 精品乱人伦一区二区三区 | 国产色网站 | 好屌妞视频这里有精品 | 自拍99| 爱爱免费小视频 | 神秘马戏团在线观看免费高清中文 | 国产成人精品一区二区三区视频 | 国产一区二区三区乱码 | 免费亚洲网站 | 久久久久久视 | 久久精品大全 | 另类专区成人 | 国产又粗又猛又爽又黄视频 | 夏晴子在线 | 午夜免费福利 | 一区二区精彩视频 | 久久久久久久美女 | 鲁一鲁一鲁一鲁一av | 偷拍中国夫妇高潮视频 | 国产精品久久久久久妇女6080 |