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

O(1) 的小樂

Job Hunting

公告

記錄我的生活和工作。。。
<2011年1月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
303112345

統(tǒng)計(jì)

  • 隨筆 - 182
  • 文章 - 1
  • 評(píng)論 - 41
  • 引用 - 0

留言簿(10)

隨筆分類(70)

隨筆檔案(182)

文章檔案(1)

如影隨形

搜索

  •  

最新隨筆

最新評(píng)論

閱讀排行榜

評(píng)論排行榜

雙連通圖 割點(diǎn)與橋 算法代碼篇

   割點(diǎn)與橋的求解都有一個(gè)前提:所求的圖是連通圖,不連通的圖沒有割點(diǎn)

 

    給每個(gè)頂點(diǎn)定義一個(gè)Low值, Low(u)表示從u出發(fā), 經(jīng)過一條其后代組成的路徑和后向邊, 所能到達(dá)的最小深度的頂點(diǎn)的編號(hào)(如果這個(gè)編號(hào)大于等于u的編號(hào), 就說明它的后代無法到達(dá)比u深度更淺的頂點(diǎn), 即無法到達(dá)u的祖先, 那么u就是個(gè)關(guān)節(jié)點(diǎn), 具體做法是在DFS每次回溯后拿剛才擴(kuò)展節(jié)點(diǎn)的Low與當(dāng)前節(jié)點(diǎn)的DFN比較, 若low>=dfn則當(dāng)前節(jié)點(diǎn)是割點(diǎn)).

Low(u)=min{DFN(u), min{Low(w)|w是u的兒子}, min{DFN(w)|(u,w) 是一條后向邊}}  DFN(u)是深搜過程中對(duì)頂點(diǎn)的編號(hào)值.

   在求割點(diǎn)的同時(shí)就可以通過一個(gè)全局的棧求出點(diǎn)的雙連通分量, 具體做法是在DFS每次由當(dāng)前頂點(diǎn)u深入下一頂點(diǎn)v時(shí), 就將邊uv進(jìn)棧, 若在函數(shù)返回后判斷出v是割點(diǎn), 則出棧, 直到uv出棧,剛才出棧的這些邊就屬于同一個(gè)點(diǎn)雙連通分量.

 

在求割點(diǎn)的同時(shí)就可以通過一個(gè)全局的棧求出點(diǎn)的雙連通分量, 具體做法是在DFS每次由當(dāng)前頂點(diǎn)u深入下一頂點(diǎn)v時(shí), 就將邊uv進(jìn)棧, 若在函數(shù)返回后判斷出v是割點(diǎn), 則出棧, 直到uv出棧,剛才出棧的這些邊就屬于同一個(gè)點(diǎn)雙連通分量.

 

來看一下幾個(gè)定義吧:

對(duì)dfs的搜索樹的定義,這是必須首先明確的,搜索樹是這樣一棵樹,他的頂點(diǎn)是圖中的頂點(diǎn),他的邊(A,B)可以說是從圖中的對(duì)應(yīng)點(diǎn)A到對(duì)應(yīng)點(diǎn)B的訪問,也可以說,樹的邊(A,B)對(duì)應(yīng)了圖中的邊(A,B),并且說明了B是從A經(jīng)過這條邊到達(dá)的
之后定義搜索順序的方式:
像(A)這樣,從U擴(kuò)展W,W為一個(gè)未擴(kuò)展到的頂點(diǎn),那么邊(U,V)叫樹枝弧
像(B)這樣從U擴(kuò)展一條路,擴(kuò)展到了V,后來返回到了U,結(jié)果有一條(U,V),這時(shí)候V已經(jīng)擴(kuò)展,邊(U,V)叫作前向弧
像 (C)這樣,從U擴(kuò)展到了V,然后再擴(kuò)展V的,擴(kuò)展V的時(shí)候發(fā)現(xiàn)有一條邊(V,U),那么邊(V,U),也就是說有一條指向祖先的邊,叫作反向弧
   (D)指向非祖先的訪問過的點(diǎn),叫作橫向弧
在無向圖中,沒有可能dfs出前向弧或者橫向弧,只有a、c

 

樹T的根是圖G的割點(diǎn),當(dāng)且僅當(dāng)其在T中至少有兩個(gè)兒子(程序中,我們使用的是son來記錄)

代碼:(Sosi coded)這個(gè)代碼求出了圖的割點(diǎn) 橋與二連通分量圖

#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;
/*
此問題是獲得圖的割,橋,與點(diǎn)連通分量圖
*/

#define  M 5000           //題目中可能的最大點(diǎn)數(shù)      
int DFN[M];                  //深度優(yōu)先搜索訪問次序
int Low[M];                  //能追溯到的最早的次序

vector <int> Edge[M];        //鄰接表表示

int Belong[M];
int Index=0;               
int CutVertexNum=0,CutVertexList[M];         //保存?zhèn)€點(diǎn)數(shù)目與割點(diǎn)         1-indexed
int BridgeNum=0,Bridgeu[M],Bridgev[M];       //保存割邊數(shù)量與割邊起始點(diǎn)   1-indexed
int BlockNum=0;vector <int> Block[M];        //保存塊數(shù)目和塊
int len,que[M];
int color=0;                                 //color 用來記錄連通分量個(gè)數(shù)

void DFS(int u,int parent)
{
    int v,son=0, beVertexCut=0;             //son記錄的是點(diǎn)u的兒子數(shù)目
    Belong[u]=-color; que[++len]=u;
    DFN[u]=Low[u]=Index++;
    for (int e=0;e<Edge[u].size();e++)
    {
        v=Edge[u][e];
        if(v!=parent)
        {
            if(Belong[v]==0)                     //樹枝邊
            {
                DFS(v,u);son++;
                Low[u]=min(Low[v],Low[u]);
                if(Low[v]>=DFN[u])
                {
                    beVertexCut=1;           //求割點(diǎn)
                    BlockNum++;
                    while(que[len]!=v){ Block[BlockNum].push_back(que[len]);cout<<que[len--]<<" ";}
                    Block[BlockNum].push_back(que[len]);Block[BlockNum].push_back(u);
                    cout<<que[len--]<<" "<<u<<endl;

                }
                if(Low[v]==DFN[v]) Bridgeu[++BridgeNum]=u,Bridgev[BridgeNum]=v;       //求割邊
            }
            else Low[u]=min(Low[u],DFN[v]);      //后向邊
        }
    }
    //非根節(jié)點(diǎn)且是割點(diǎn) 或者  根節(jié)點(diǎn)且兒子至少有兩個(gè)
    if((parent&& beVertexCut)||(!parent&&son>1)) CutVertexList[++CutVertexNum]=u;
    Belong[u]=color;
}
void dfs(int N)
{
    memset(DFN,-1,sizeof(DFN));
    memset(Low,-1,sizeof(Low));
    memset(CutVertexList,-1,sizeof(CutVertexList));
    memset(Bridgeu,-1,sizeof(Bridgeu));
    memset(Bridgev,-1,sizeof(Bridgev));
    memset(Belong,0,sizeof(Belong));     //所有的塊號(hào)都大于等于1
    for(int i=0;i<N;i++)
    {
        if(!Belong[i])
        {
            ++color,len=0,DFSCUT(i,0);
            if(len>1||DFN[i]==Index)
            {
                BlockNum++;
                while(len>1){ Block[BlockNum].push_back(que[len]);cout<<que[len--]<<" ";}
                Block[BlockNum].push_back(i);
                cout<<i<<endl;
            }
        }
    }

}

void reshape(int N)     //縮點(diǎn)形成新圖,N為圖中的點(diǎn)數(shù)
{
    if(color==1)
    {
    cout<<"CutVertexNum    "<<CutVertexNum<<endl;
    for(int i=1;i<=CutVertexNum;i++)
    {
        cout<<CutVertexList[i]<<" ";
    }
    cout<<endl;

    cout<<"BridgeNum    "<<BridgeNum<<endl;
    for(int i=1;i<=BridgeNum;i++)
    {
        cout<<Bridgeu[i]<<"   to     "<<Bridgev[i]<<endl;
    }
    cout<<endl;
    cout<<"Color"<<color<<endl;
    for(int i=0;i<N;i++)
        cout<<Belong[i]<<"    ";
    cout<<endl;

    cout<<"Block"<<BlockNum<<endl;
    for(int i=1;i<=BlockNum;i++)
    {
        for(int j=0;j<Block[i].size();j++)
        {
            cout<<Block[i][j]<<" ";
        }
        cout<<endl;
    }
    }
    else
        cout<<"It`s not a connected graph"<<endl;
}
/*
此算法正常工作的基礎(chǔ)是圖是0-indexed的。
*/
int main()
{
    Edge[0].push_back(1),Edge[0].push_back(2);
    Edge[1].push_back(0),Edge[1].push_back(2);
    Edge[2].push_back(0),Edge[2].push_back(1),Edge[2].push_back(3);
    Edge[3].push_back(2),Edge[3].push_back(4);
    Edge[4].push_back(5);
    Edge[5].push_back(4);
    int N=6;
    dfs(N);
    reshape(N);

    return 0;
}

 

 

 

 

[圖的雙連通性問題例題]

備用交換機(jī)
求圖的割點(diǎn),直接輸出。

pku 3177(3352) Redundant Paths
求橋,收縮邊雙連通子圖,構(gòu)造邊雙連通圖。

POI 1999 倉庫管理員 Store-keeper
求點(diǎn)雙連通子圖。

一些題目:

http://m.shnenglu.com/Uriel/articles/121169.html

http://www.chenyajun.com/tag/%E5%BC%BA%E8%BF%9E%E9%80%9A%E5%88%86%E9%87%8F

http://www.cnblogs.com/zhjjla/archive/2010/05/21/1741180.html

http://www.robin47.com/archives/423

 

Reference:

http://www.byvoid.com/blog/biconnect/         byvoid的NX文章

posted on 2010-09-28 21:45 Sosi 閱讀(1493) 評(píng)論(1)  編輯 收藏 引用

評(píng)論

# re: 雙連通圖 割點(diǎn)與橋 算法代碼篇 2012-07-09 17:46 Ramirez26Candace

Some specialists say that <a href="http://goodfinance-blog.com">loans</a> help people to live their own way, because they can feel free to buy necessary goods. Furthermore, different banks present student loan for all people.

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


統(tǒng)計(jì)系統(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>
            欧美sm视频| 尤物精品在线| 国产精品男人爽免费视频1| 国产亚洲一区二区精品| 久久美女性网| 欧美日韩综合在线免费观看| 在线观看国产精品网站| 欧美怡红院视频一区二区三区| 欧美 日韩 国产一区二区在线视频 | 久久精品日产第一区二区三区| 久久精品二区亚洲w码| 亚洲视频网在线直播| 国产精品欧美一区二区三区奶水| 午夜精品国产更新| 亚洲高清久久| 在线一区二区三区四区| 欧美福利视频一区| 蘑菇福利视频一区播放| 亚洲一二三区视频在线观看| 亚洲欧美日韩成人高清在线一区| 午夜精品久久久99热福利| 欧美在线免费播放| 最新亚洲激情| 国产精品久久久久毛片软件| 亚洲欧美综合| 欧美一级在线播放| 亚洲高清免费在线| 亚洲高清激情| 国产精品国产三级国产aⅴ入口 | 亚洲第一毛片| 在线亚洲一区| 亚洲国产美女久久久久| 亚洲乱码国产乱码精品精天堂 | 一区二区不卡在线视频 午夜欧美不卡'| 亚洲视屏在线播放| 亚洲一区二区在线播放| 欧美色欧美亚洲另类二区| 久久综合导航| 国产亚洲精品一区二区| 欧美大片免费观看在线观看网站推荐| 欧美成人免费小视频| 欧美高清不卡在线| 亚洲图片欧美午夜| 欧美在线亚洲在线| 亚洲免费精品| 欧美一区激情| 亚洲午夜精品网| 欧美在线观看网址综合| 亚洲免费视频网站| 欧美大片va欧美在线播放| 欧美中文字幕在线| 国产精品久久久久影院色老大 | 午夜精品三级视频福利| 欧美日本韩国一区| 美女91精品| 在线观看欧美精品| 免费一级欧美片在线播放| 欧美亚一区二区| 亚洲激情黄色| 欧美激情一级片一区二区| 午夜精品久久久久久99热软件| 亚洲美女91| 欧美日韩一区精品| aa级大片欧美| 午夜性色一区二区三区免费视频| 欧美日韩国产首页在线观看| 久久精品动漫| 日韩视频在线观看免费| 亚洲视频碰碰| 亚洲精品视频啊美女在线直播| 麻豆精品在线观看| 亚洲丶国产丶欧美一区二区三区 | 亚洲欧美一区二区视频| 亚洲精品一区二区三区福利| 欧美在线综合| 午夜精品在线看| 亚洲国产精品久久久久久女王| 国产一区二区毛片| 欧美日韩一区二区三区| 欧美影院精品一区| 亚洲国产成人porn| 久久偷窥视频| 亚洲一区二区视频在线| 亚洲国产精品成人久久综合一区| 欧美人成免费网站| 欧美一级片在线播放| 久久激情综合| 欧美一区二区三区视频在线观看 | 亚洲欧美电影院| 久久久久久一区二区| 久久五月激情| 欧美日韩国产三区| 国产精品久久久久高潮| 亚洲欧美在线免费观看| 国产精品美腿一区在线看| 欧美国产在线观看| 日韩视频专区| 亚洲激情影院| 久久精品国产精品| 久久久精彩视频| 国产精品久久久久久久久搜平片| 亚洲国产精品成人综合| 伊人久久久大香线蕉综合直播 | 欧美成人综合网站| 黄色日韩精品| 久久久久国产精品麻豆ai换脸| 久久成人久久爱| 国产精品v亚洲精品v日韩精品| 亚洲精品永久免费精品| 亚洲网站视频| 国产精品免费在线| 午夜欧美电影在线观看| 久久精品一二三| 激情五月婷婷综合| 老司机午夜精品视频| 亚洲电影免费观看高清| 亚洲黄色在线看| 欧美剧在线免费观看网站| 亚洲欧洲美洲综合色网| 一本色道久久综合| 国产精品大片wwwwww| 亚洲欧美日韩一区二区三区在线观看| 欧美视频三区在线播放| 亚洲欧美日韩在线观看a三区| 国产精品女主播一区二区三区| 亚洲免费在线播放| 久久久久高清| 亚洲精品国久久99热| 欧美日韩小视频| 亚洲欧美激情一区| 奶水喷射视频一区| 亚洲视频1区| 国产日本亚洲高清| 麻豆成人小视频| 日韩一区二区精品| 久久高清一区| 极品日韩久久| 欧美日韩国产精品| 欧美一区国产在线| 亚洲精品视频在线| 久久福利毛片| 欧美性大战xxxxx久久久| 欧美一区=区| 亚洲欧洲精品一区二区精品久久久| 午夜精品久久久久久| 最新精品在线| 国产日韩精品在线| 欧美成人午夜77777| 亚洲一区不卡| 欧美护士18xxxxhd| 香蕉成人久久| 亚洲国产精品久久久久婷婷老年| 欧美日韩精品免费看| …久久精品99久久香蕉国产| 欧美香蕉视频| 久久网站免费| 午夜精品久久久久久99热| 国产一区二区三区直播精品电影 | 91久久国产综合久久91精品网站| 亚洲午夜精品一区二区| 永久域名在线精品| 国产精品久久| 欧美成人有码| 欧美亚洲一区| 亚洲深夜福利| 亚洲欧洲一区二区三区| 久久在线播放| 欧美在线一二三区| 亚洲网友自拍| 99国产精品久久久久久久| 精品成人国产| 国产亚洲一区二区三区在线观看| 欧美日韩一区二区三区免费看| 久久久亚洲一区| 欧美在线免费视频| 亚洲淫片在线视频| 在线视频亚洲一区| 日韩视频免费在线观看| 亚洲国产婷婷香蕉久久久久久| 乱人伦精品视频在线观看| 激情婷婷久久| 亚洲无吗在线| 夜夜嗨av一区二区三区| 欧美黄色影院| 美女图片一区二区| 久久婷婷国产综合尤物精品| 久久精品99国产精品日本| 亚洲欧美日韩在线不卡| 亚洲欧美精品一区| 亚洲女人天堂成人av在线| 中国成人亚色综合网站| 亚洲天堂av在线免费观看| 亚洲视频第一页| 99精品热视频只有精品10| 欧美性一区二区| 欧美日韩一区三区| 国产精品igao视频网网址不卡日韩| 欧美日韩一区高清| 国产乱子伦一区二区三区国色天香| 国产精品嫩草99av在线|