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

O(1) 的小樂

Job Hunting

公告

記錄我的生活和工作。。。
<2010年9月>
2930311234
567891011
12131415161718
19202122232425
262728293012
3456789

統計

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

留言簿(10)

隨筆分類(70)

隨筆檔案(182)

文章檔案(1)

如影隨形

搜索

  •  

最新隨筆

最新評論

閱讀排行榜

評論排行榜

雙連通圖 割點與橋 算法代碼篇

   割點與橋的求解都有一個前提:所求的圖是連通圖,不連通的圖沒有割點

 

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

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

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

 

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

 

來看一下幾個定義吧:

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

 

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

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

#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 5000           //題目中可能的最大點數      
int DFN[M];                  //深度優先搜索訪問次序
int Low[M];                  //能追溯到的最早的次序

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

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

void DFS(int u,int parent)
{
    int v,son=0, beVertexCut=0;             //son記錄的是點u的兒子數目
    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;           //求割點
                    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]);      //后向邊
        }
    }
    //非根節點且是割點 或者  根節點且兒子至少有兩個
    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));     //所有的塊號都大于等于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)     //縮點形成新圖,N為圖中的點數
{
    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;
}
/*
此算法正常工作的基礎是圖是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;
}

 

 

 

 

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

備用交換機
求圖的割點,直接輸出。

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

POI 1999 倉庫管理員 Store-keeper
求點雙連通子圖。

一些題目:

http://www.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 閱讀(1502) 評論(1)  編輯 收藏 引用

評論

# re: 雙連通圖 割點與橋 算法代碼篇 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.
  回復  更多評論    

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


統計系統
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            开心色5月久久精品| 亚洲日韩中文字幕在线播放| 亚洲国产欧洲综合997久久| 欧美午夜视频网站| 亚洲欧洲偷拍精品| 亚洲国产成人高清精品| 欧美一区二区三区视频免费| 亚洲欧美日韩在线一区| 欧美精品电影在线| 亚洲国产精品成人| 亚洲电影第三页| 久久视频在线看| 老司机凹凸av亚洲导航| 好吊色欧美一区二区三区视频| 亚洲视频欧美视频| 亚洲一区二区三区四区中文| 欧美精品日韩一本| 亚洲免费观看| 中文网丁香综合网| 欧美日韩在线不卡| a4yy欧美一区二区三区| 99精品视频免费| 欧美日韩不卡一区| 亚洲最新中文字幕| 亚洲伊人久久综合| 国产精品免费视频xxxx| 亚洲综合精品四区| 久久久久欧美精品| 在线观看中文字幕亚洲| 蜜臀av性久久久久蜜臀aⅴ| 女同一区二区| 亚洲美女黄网| 欧美视频在线观看免费| 亚洲一品av免费观看| 欧美在线视频全部完| 好吊日精品视频| 老司机精品视频一区二区三区| 欧美激情在线免费观看| 99国产精品久久久久久久| 欧美系列亚洲系列| 欧美一区二区三区四区在线| 你懂的网址国产 欧美| 亚洲精品久久久一区二区三区| 欧美精品日本| 西西人体一区二区| 欧美成人福利视频| 夜夜躁日日躁狠狠久久88av| 国产精品成人国产乱一区| 午夜精品成人在线视频| 免费久久99精品国产| 99精品国产99久久久久久福利| 欧美日韩亚洲一区二区| 性欧美精品高清| 亚洲国产欧美久久| 午夜精品一区二区三区在线| 在线不卡亚洲| 欧美三区在线观看| 久久国产精品电影| 亚洲卡通欧美制服中文| 久久精品国产免费观看| 亚洲精品日韩激情在线电影| 国产精品午夜电影| 欧美va天堂在线| 午夜视黄欧洲亚洲| 亚洲精品久久久一区二区三区| 久久爱91午夜羞羞| 一区二区三区波多野结衣在线观看| 国产精品久久久久久久久久免费看| 久久婷婷国产综合尤物精品| 一区二区三区免费网站| 欧美激情偷拍| 久久久久国产精品一区三寸| 亚洲精品四区| 在线精品国产成人综合| 国产精品丝袜91| 欧美激情一二区| 久久九九99| 亚洲欧美精品中文字幕在线| 亚洲乱码一区二区| 欧美激情精品久久久久| 久久久精品2019中文字幕神马| 亚洲天堂黄色| 99re亚洲国产精品| 亚洲国产毛片完整版| 国产一区二区三区高清在线观看| 欧美午夜精品久久久久免费视| 欧美成人午夜视频| 久久精品亚洲| 欧美在线中文字幕| 新67194成人永久网站| 亚洲一区二区三区色| 亚洲美女视频在线免费观看| 欧美激情小视频| 欧美国产第二页| 老司机免费视频一区二区| 久久久国产精品亚洲一区 | 亚洲一区二区三区精品视频| 亚洲精品国产精品久久清纯直播 | 亚洲无线观看| 99视频国产精品免费观看| 亚洲国产综合91精品麻豆| 怡红院精品视频| 激情视频一区| 怡红院精品视频在线观看极品| 国内精品视频一区| 国产日韩欧美| 国产亚洲欧美日韩日本| 国产一区二区欧美| 黄色在线成人| 在线成人免费观看| 亚洲福利视频一区二区| 亚洲人成人一区二区在线观看| 亚洲日本va在线观看| 91久久精品一区二区别| 亚洲美女淫视频| aa级大片欧美| 亚洲欧美激情四射在线日 | 久久成人免费电影| 性18欧美另类| 久久久久久久精| 久久夜色精品国产噜噜av| 免费中文日韩| 欧美日本不卡高清| 国产精品豆花视频| 国产日韩精品一区| 红桃av永久久久| 亚洲精品乱码久久久久久蜜桃91 | 久久午夜影视| 欧美大片免费久久精品三p| 欧美日韩国产影片| 国产精品日日摸夜夜添夜夜av| 国产欧美一区二区精品仙草咪| 黄色成人免费观看| 亚洲九九爱视频| 亚洲欧美国产视频| 乱人伦精品视频在线观看| 亚洲黄网站黄| 亚洲影院在线| 免费成人美女女| 国产精品视区| 激情久久五月| 亚洲午夜在线| 美女黄色成人网| 99精品久久免费看蜜臀剧情介绍| 欧美一区二区三区四区夜夜大片| 麻豆成人综合网| 国产精品推荐精品| 91久久精品www人人做人人爽| 午夜精品久久久久久久久久久久| 嫩草伊人久久精品少妇av杨幂| 中文国产成人精品久久一| 久久综合色婷婷| 国产精品一区二区a| 亚洲精品免费在线| 久久精品亚洲一区二区三区浴池| 亚洲国产精品久久人人爱蜜臀| 亚洲欧美日韩一区二区三区在线 | 国产亚洲一区二区三区| 99视频日韩| 你懂的亚洲视频| 午夜欧美精品| 欧美午夜电影一区| 亚洲国产午夜| 久久三级视频| 亚洲一区二区三区四区视频| 欧美精品www在线观看| 一区二区三区亚洲| 欧美资源在线| 中文网丁香综合网| 欧美精品粉嫩高潮一区二区| 精品动漫av| 久久久国产精品一区| 亚洲一区二区视频在线| 欧美久久视频| 亚洲国内精品| 欧美大片免费久久精品三p | 亚洲精品色图| 欧美成人一区二区三区在线观看 | 亚洲婷婷综合色高清在线| 欧美精品久久一区| 亚洲国产欧美久久| 欧美成人日韩| 久久久久国产精品www| 狠狠干成人综合网| 久久亚洲综合色| 久久久久.com| 在线播放中文字幕一区| 久久久亚洲一区| 久久国产一区二区三区| 国产日韩在线一区| 久久精品一级爱片| 久久精品一区中文字幕| 精品91在线| 欧美高清视频在线观看| 美女网站久久| aa日韩免费精品视频一| 99精品国产福利在线观看免费| 欧美日韩在线高清| 午夜视频一区二区| 久久国产综合精品|