青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

O(1) 的小樂

Job Hunting

公告

記錄我的生活和工作。。。
<2025年12月>
30123456
78910111213
14151617181920
21222324252627
28293031123
45678910

統(tǒng)計

  • 隨筆 - 182
  • 文章 - 1
  • 評論 - 41
  • 引用 - 0

留言簿(10)

隨筆分類(70)

隨筆檔案(182)

文章檔案(1)

如影隨形

搜索

  •  

最新隨筆

最新評論

閱讀排行榜

評論排行榜

有向圖強(qiáng)連通分量 Gabow 算法

 

When the depth-first search reaches a vertex v, the algorithm performs the following steps:

  1. Set the preorder number of v to C, and increment C.
  2. Push v onto S and also onto P.
  3. For each edge from v to a neighboring vertex w:
    • If the preorder number of w has not yet been assigned, recursively search w;
    • Otherwise, if w has not yet been assigned to a strongly connected component:
      • Repeatedly pop vertices from P until the top element of P has a preorder number less than or equal to the preorder number of w.
  4. If v is the top element of P:
    • Pop vertices from S until v has been popped, and assign the popped vertices to a new component.
    • Pop v from P.

 

Gabow_Algorithm偽代碼:

step1:

找一個沒有被訪問過的節(jié)點v,goto step2(v)。否則,算法結(jié)束。

step2(v):

將v壓入堆棧stk1[]和stk2[]

對于v所有的鄰接頂點u:

1) 如果沒有訪問過,則step2(u)

2) 如果訪問過,但沒有刪除,維護(hù)stk2[](處理環(huán)的過程,在stk2 中刪除構(gòu)成環(huán)的節(jié)點)

如果stk2[]的頂元素==v,那么輸出相應(yīng)的強(qiáng)連通分量

 

這個算法其實就是Tarjan算法的變異體,我們觀察一下,只是它用第二個堆棧來輔助求出強(qiáng)連通分量的根,而不是Tarjan算法里面的DFN[]和Low[]數(shù)組。那么,我們說一下如何使用第二個堆棧來輔助求出強(qiáng)連通分量的根。

我們使用類比方法,在Tarjan算法中,每次Low[i]的修改都是由于環(huán)的出現(xiàn)(不然,Low[i]的值不可能變小),每次出現(xiàn)環(huán),在這個環(huán)里面只剩下一個Low[i]沒有被改變(深度最低的那個),或者全部被改變,因為那個深度最低的節(jié)點在另一個環(huán)內(nèi)。那么Gabow算 法中的第二堆棧變化就是刪除構(gòu)成環(huán)的節(jié)點,只剩深度最低的節(jié)點,或者全部刪除,這個過程是通過出棧來實現(xiàn),因為深度最低的那個頂點一定比前面的先訪問,那 么只要出棧一直到棧頂那個頂點的訪問時間不大于深度最低的那個頂點。其中每個被彈出的節(jié)點屬于同一個強(qiáng)連通分量。那有人會問:為什么彈出的都是同一個強(qiáng)連 通分量?因為在這個節(jié)點訪問之前,能夠構(gòu)成強(qiáng)連通分量的那些節(jié)點已經(jīng)被彈出了,這個對Tarjan算法有了解的都應(yīng)該清楚,那么Tarjan算法中的判斷根我們用什么來代替呢?想想,其實就是看看第二個堆棧的頂元素是不是當(dāng)前頂點就可以了。

現(xiàn)在,你應(yīng)該明白其實Tarjan算法和Gabow算法其實是同一個思想的不同實現(xiàn),但是,Gabow算法更精妙,時間更少(不用頻繁更新Low[])。

 

QQ截圖未命名

 

代碼:

#include "cstdlib"
#include "cctype"
#include "cstring"
#include "cstdio"
#include "cmath"
#include "algorithm"
#include "vector"
#include "string"
#include "iostream"
#include "sstream"
#include "set"
#include "queue"
#include "stack"
#include "fstream"
#include "strstream"
using namespace std;

#define  M 2000              //題目中可能的最大點數(shù)      
int STACK[M],top=0;          //Gabow 算法中的輔助棧
int STACK2[M],top2=0;        //
int DFN[M];                  //深度優(yōu)先搜索訪問次序
int ComponetNumber=0;        //有向圖強(qiáng)連通分量個數(shù)
int Index=0;                 //索引號
int Belong[M];               //某個點屬于哪個連通分支
vector <int> Edge[M];        //鄰接表表示
vector <int> Component[M];   //獲得強(qiáng)連通分量結(jié)果

void Gabow(int i)
{
    int j;
    DFN[i]=Index++;
    STACK[++top]=i;
    STACK2[++top2]=i;
    for (int e=0;e<Edge[i].size();e++)
    {
        j=Edge[i][e];
        if (DFN[j]==-1)  Gabow(j);
        else if (Belong[j]==-1)       //如果訪問過,但沒有刪除,維護(hù)STACK2
        {
            while(DFN[STACK2[top2]]>DFN[j])        //刪除構(gòu)成環(huán)的頂點
                top2--;
        }
    }
    if(i==STACK2[top2])               //如果Stack2 的頂元素等于i,輸出相應(yīng)的強(qiáng)連通分量
    {
        --top2; ++ComponetNumber;
        do
        {
            Belong[STACK[top]]=ComponetNumber;
            Component[ComponetNumber].push_back(STACK[top]);
        }while ( STACK[top--]!=i);
    }
}

void solve(int N)     //此圖中點的個數(shù),注意是0-indexed!
{
    memset(STACK,-1,sizeof(STACK));
    memset(STACK2,-1,sizeof(STACK2));
    memset(Belong,-1,sizeof(Belong));
    memset(DFN,-1,sizeof(DFN));

    for(int i=0;i<N;i++)
        if(DFN[i]==-1)
            Gabow(i);   
}
/*
此算法正常工作的基礎(chǔ)是圖是0-indexed的。但是獲得的結(jié)果Component數(shù)組和Belong數(shù)組是1-indexed
*/
int main()
{
    Edge[0].push_back(1);Edge[0].push_back(2);
    Edge[1].push_back(3);
    Edge[2].push_back(3);Edge[2].push_back(4);
    Edge[3].push_back(0);Edge[3].push_back(5);
    Edge[4].push_back(5);
    int  N=6;
    solve(N);
    cout<<"ComponetNumber is "<<ComponetNumber<<endl;
    for(int i=0;i<N;i++)
            cout<<Belong[i]<<" ";
    cout<<endl;
    for(int i=0;i<N;i++)
    {
        for(int j=0;j<Component[i].size();j++)
            cout<<Component[i][j];
        cout<<endl;
    }
    return 0;
}

 

Reference:

http://rchardx.is-programmer.com/posts/14898.html

wiki

 

終于搞完了SCC問題的3大算法:

小總結(jié)一下:

 

三種算法的時間復(fù)雜度都是O(M+N) (N為圖的點數(shù),M為邊數(shù))

 

Tarjan 算法和Gabow算法思想類似,在Tarjan算法中用Low[]數(shù)組來記錄所能達(dá)到的最小時間戳,而Gabow算法則是用Stack2[]輔助獲得了強(qiáng)連通分量的根!

二者實質(zhì)是一樣的!

 

Kosaraju 算法則是兩次DFS,所以在時間復(fù)雜度常數(shù)因子的比拼上,肯定拼不過 Tarjan Gabow,但是額外的常數(shù)帶來了良好的拓?fù)湫再|(zhì)!它得到的節(jié)點是按照拓?fù)湫蚪M織好的,在求解2-SAT的過程中十分方便。

 

下面是題目來總結(jié)或者來一個求無向圖雙連通分量Tarjan算法 和求最近公共祖先的離線Tarjan算法!

 

再引用一次:

Tarjan算法與求無向圖的雙連通分量(割點、橋)的Tarjan算法也有著很深的聯(lián)系。學(xué)習(xí)該Tarjan算法,也有助于深入理解求雙連通分量的Tarjan算法,兩者可以類比、組合理解。

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

posted on 2010-09-27 14:07 Sosi 閱讀(1433) 評論(2)  編輯 收藏 引用

評論

# re: 有向圖強(qiáng)連通分量 Gabow 算法 2012-04-18 23:06 劉濤

您好,我用您的程序求有向圖的強(qiáng)連通分量。但是當(dāng)點數(shù)很多的時候,總是顯示stack overflow,我的編譯器是vs2008.請問怎么解決這個問題,謝謝。
您寫的程序真心不錯,謝謝您的饋贈。
  回復(fù)  更多評論    

# re: 有向圖強(qiáng)連通分量 Gabow 算法 2012-11-07 14:35 ynkdyx@sohu.com

話說這不就是棧溢出了么,寫的很明白了。如果怕棧溢出就把內(nèi)存開大好了,再用上STL里的vector即可。@劉濤
  回復(fù)  更多評論    

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


統(tǒng)計系統(tǒng)
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲三级观看| 亚洲欧美日韩国产中文在线| 久久成人在线| 国内成人精品一区| 久久中文在线| 欧美成人黄色小视频| 亚洲精品四区| 一区二区三区蜜桃网| 国产精品色网| 久久人人爽人人| 免费亚洲一区| 中文精品视频一区二区在线观看| 99精品视频免费观看视频| 国产精品私房写真福利视频| 久久电影一区| 免费国产一区二区| 亚洲私拍自拍| 久久精品日韩| 亚洲剧情一区二区| 午夜激情久久久| 亚洲激情电影在线| 亚洲美女少妇无套啪啪呻吟| 国产精品免费一区二区三区在线观看 | 国产日产高清欧美一区二区三区| 久久久久久久久久久一区| 嫩模写真一区二区三区三州| 亚洲综合电影一区二区三区| 久久se精品一区精品二区| 亚洲国产三级| 亚洲在线观看视频| 亚洲精品在线观看视频| 午夜精品久久久久久久男人的天堂| 一区在线免费观看| 在线一区亚洲| 亚洲精品黄网在线观看| 亚洲欧美日韩人成在线播放| 亚洲精品久久久一区二区三区| 亚洲综合色网站| 亚洲最快最全在线视频| 久久精品国产精品| 亚洲免费在线电影| 欧美va天堂| 久久久久青草大香线综合精品| 欧美日韩高清不卡| 欧美黄色影院| 一区二区三区在线观看欧美| 亚洲视屏一区| 一本色道久久综合亚洲精品不卡| 欧美影院久久久| 午夜久久久久| 欧美三区在线视频| 亚洲人成免费| 亚洲区一区二| 老司机精品久久| 狂野欧美一区| 国产亚洲欧美aaaa| 亚洲一区二区精品视频| 亚洲视频在线看| 欧美久久久久| 亚洲国产婷婷香蕉久久久久久| 在线成人免费观看| 久久se精品一区精品二区| 欧美一区二区| 国产精品一区二区三区免费观看 | 久久久久久穴| 国内偷自视频区视频综合| 亚洲欧美日韩在线播放| 午夜在线精品偷拍| 国产欧美日韩在线| 欧美亚洲综合网| 久久亚洲免费| 91久久国产综合久久91精品网站| 久久久精品网| 亚洲缚视频在线观看| 亚洲欧洲一区二区天堂久久 | 午夜精品久久久久久久99水蜜桃| 亚洲资源av| 国产伦精品一区二区三区视频黑人| 亚洲午夜国产一区99re久久| 欧美亚洲三区| 黄网动漫久久久| 久久久五月婷婷| 亚洲电影在线| 一区二区三区日韩| 国产精品香蕉在线观看| 久久高清一区| 亚洲第一视频网站| 中文国产成人精品| 国产精品视频福利| 久久免费少妇高潮久久精品99| 欧美激情在线有限公司| 亚洲一区在线直播| 国产亚洲成年网址在线观看| 久久久夜夜夜| 99亚洲视频| 久久精品日韩一区二区三区| 亚洲激情影院| 国产精品一区二区你懂得| 久久九九99视频| 99国内精品久久| 久久精品女人| 这里只有精品在线播放| 国产日韩欧美成人| 欧美激情国产高清| 午夜视频一区二区| 亚洲福利视频一区二区| 欧美在线地址| aⅴ色国产欧美| 精品成人一区二区三区| 欧美日韩免费观看一区| 久久精品在线视频| 亚洲天堂成人| 亚洲国产欧美久久| 久久亚洲精选| 午夜精品亚洲| 亚洲精品一区二区三区在线观看| 国产欧美一区二区三区在线看蜜臀| 麻豆成人在线观看| 久久成人国产| 亚洲天堂成人| 亚洲蜜桃精久久久久久久| 欧美波霸影院| 久久久久久精| 亚洲欧美日本在线| 国产精品99久久久久久久久| 伊人久久婷婷| 国产午夜亚洲精品不卡| 欧美色中文字幕| 欧美激情一区二区三区四区| 久久综合伊人77777麻豆| 亚洲免费视频在线观看| 宅男噜噜噜66国产日韩在线观看| 欧美国产日本| 欧美激情亚洲国产| 麻豆精品网站| 久久综合九色欧美综合狠狠| 欧美综合77777色婷婷| 午夜伦理片一区| 亚洲欧美久久久久一区二区三区| 99热这里只有成人精品国产| 亚洲国产另类精品专区| 在线免费日韩片| 一区免费观看视频| 狠狠色综合日日| 伊人久久大香线蕉综合热线| 狠狠久久亚洲欧美专区| 一区在线电影| 亚洲国产成人精品久久| 在线日韩欧美| 亚洲激情偷拍| 99国产精品视频免费观看一公开 | 国产精品a久久久久| 欧美日韩妖精视频| 国产精品极品美女粉嫩高清在线| 国产精品高潮粉嫩av| 国产精品女人毛片| 国产午夜精品久久久久久久| 国产欧美一区二区三区另类精品| 国产亚洲一级高清| 1769国内精品视频在线播放| 亚洲国产精品久久久| 日韩一级免费| 午夜视频在线观看一区| 久久精品国产一区二区三区免费看 | 国产综合色在线视频区| 伊人激情综合| 一区二区不卡在线视频 午夜欧美不卡在| 日韩亚洲精品在线| 亚洲欧美大片| 久久久亚洲欧洲日产国码αv| 欧美不卡视频| 亚洲美女啪啪| 欧美一区二区高清| 嫩草成人www欧美| 欧美日韩一区自拍| 国外成人网址| 一区二区三区精密机械公司| 午夜精品影院| 欧美激情一区在线| 亚洲自拍三区| 欧美成年网站| 国产日韩欧美在线播放不卡| 亚洲精品一二三| 久久国产天堂福利天堂| 亚洲国产精品免费| 亚洲欧美视频在线观看视频| 欧美成人一区在线| 国产一区二区三区四区老人| 亚洲免费观看高清在线观看| 久久精品视频一| 亚洲美女av黄| 久久视频在线看| 国产区在线观看成人精品| 亚洲人永久免费| 久久综合一区| 亚洲小说区图片区| 欧美金8天国| 亚洲第一毛片| 久久久久久九九九九| 一区二区三区四区精品|