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

POJ 1523 SPF 割點(diǎn)+分割連通塊的數(shù)量

Description

Consider the two networks shown below. Assuming that data moves around these networks only between directly connected nodes on a peer-to-peer basis, a failure of a single node, 3, in the network on the left would prevent some of the still available nodes from communicating with each other. Nodes 1 and 2 could still communicate with each other as could nodes 4 and 5, but communication between any other pairs of nodes would no longer be possible.

Node 3 is therefore a Single Point of Failure (SPF) for this network. Strictly, an SPF will be defined as any node that, if unavailable, would prevent at least one pair of available nodes from being able to communicate on what was previously a fully connected network. Note that the network on the right has no such node; there is no SPF in the network. At least two machines must fail before there are any pairs of available nodes which cannot communicate.

Input

The input will contain the description of several networks. A network description will consist of pairs of integers, one pair per line, that identify connected nodes. Ordering of the pairs is irrelevant; 1 2 and 2 1 specify the same connection. All node numbers will range from 1 to 1000. A line containing a single zero ends the list of connected nodes. An empty network description flags the end of the input. Blank lines in the input file should be ignored.

Output

For each network in the input, you will output its number in the file, followed by a list of any SPF nodes that exist.

The first network in the file should be identified as "Network #1", the second as "Network #2", etc. For each SPF node, output a line, formatted as shown in the examples below, that identifies the node and the number of fully connected subnets that remain when that node fails. If the network has no SPF nodes, simply output the text "No SPF nodes" instead of a list of SPF nodes.

Sample Input

1 2
5 4
3 1
3 2
3 4
3 5
0
1 2
2 3
3 4
4 5
5 1
0
1 2
2 3
3 4
4 6
6 3
2 5
5 1
0
0

Sample Output

Network #1
SPF node 3 leaves 2 subnets
Network #2
No SPF nodes
Network #3
SPF node 2 leaves 2 subnets
SPF node 3 leaves 2 subnets

Source


    圖論,又是一道割點(diǎn)的題,并且還要求出圖中所有的割點(diǎn)分別能將圖分割成幾個(gè)不同的塊。可以將某個(gè)割點(diǎn)的訪問標(biāo)記設(shè)置為1,然后對(duì)圖進(jìn)行dfs,方法類似求圖中有幾個(gè)連通的區(qū)域。
#include <iostream>
#include 
<vector>
using namespace std;

const int MAXN = 1010;
bool flag,cut[MAXN],visit[MAXN];
vector
< vector<int> > adj;
int mark[MAXN],deep[MAXN],ancestor[MAXN];

void dfs(int u,int father,int depth){
    
int i,v,son=0,len=adj[u].size();
    mark[u]
=1,deep[u]=ancestor[u]=depth;
    
for(i=0;i<len;i++){
        v
=adj[u][i];
        
if(v!=father && mark[v]==1)
            ancestor[u]
=min(ancestor[u],deep[v]);
        
if(mark[v]==0){
            dfs(v,u,depth
+1);
            son
=son+1;
            ancestor[u]
=min(ancestor[u],ancestor[v]);
            
if((father==-1 && son>1|| (father!=-1 && ancestor[v]>=deep[u]))
                cut[u]
=true;
        }

    }

    mark[u]
=2;
}

void partition(int u){
    visit[u]
=true;
    
int i,len=adj[u].size();
    
for(i=0;i<len;i++)
        
if(!visit[adj[u][i]])
            partition(adj[u][i]);
}

int main(){
    
int i,j,x,y,n,cnt,ca=1;
    
while(scanf("%d",&x),x){
        scanf(
"%d",&y);
        adj.assign(MAXN,vector
<int>());
        n
=max(x,y);
        adj[x
-1].push_back(y-1),adj[y-1].push_back(x-1);
        
while(scanf("%d",&x)){
            
if(x==0break;
            scanf(
"%d",&y);
            n
=max(x,y);
            adj[x
-1].push_back(y-1),adj[y-1].push_back(x-1);
        }

        memset(cut,
false,sizeof(cut));
        memset(mark,
0,sizeof(mark));
        
for(i=0;i<n;i++)
            
if(mark[i]==0
                dfs(
0,-1,0);
        printf(
"Network #%d\n",ca++);
        
for(flag=false,i=0;i<n;i++)
            
if(cut[i]){
                flag
=true;
                memset(visit,
false,sizeof(visit));
                
for(visit[i]=true,cnt=j=0;j<n;j++)
                    
if(!visit[j])
                        partition(j),cnt
++;
                printf(
"  SPF node %d leaves %d subnets\n",i+1,cnt);
            }

        
if(!flag)
            printf(
"  No SPF nodes\n");
        printf(
"\n");
    }

    
return 0;
}

posted on 2009-05-28 19:18 極限定律 閱讀(1122) 評(píng)論(0)  編輯 收藏 引用 所屬分類: ACM/ICPC

<2009年6月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

導(dǎo)航

統(tǒng)計(jì)

常用鏈接

留言簿(10)

隨筆分類

隨筆檔案

友情鏈接

搜索

最新評(píng)論

閱讀排行榜

評(pí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>
            日韩网站在线观看| 欧美日韩在线播| 亚洲在线免费观看| 久久一区精品| 久久成人一区二区| 欧美性猛交xxxx免费看久久久| 久久婷婷麻豆| 国产欧美日韩| 一区二区三区不卡视频在线观看 | 欧美激情一区二区三区四区| 久久视频这里只有精品| 国产精品免费观看视频| 亚洲精品一区二区在线| 亚洲日本黄色| 久久天天躁夜夜躁狠狠躁2022 | 亚洲精品自在在线观看| 亚洲国产精品精华液2区45| 久久成人18免费网站| 欧美一区1区三区3区公司| 欧美四级剧情无删版影片| 亚洲国产日韩一区| 尤物在线精品| 久久视频在线免费观看| 久久一区二区三区四区| 激情久久久久久久久久久久久久久久| 亚洲欧美日韩另类| 欧美一区2区三区4区公司二百| 欧美性做爰毛片| 亚洲午夜在线观看视频在线| 亚洲影院免费| 国产精品人成在线观看免费| 一区二区三区四区在线| 亚洲欧美一区二区原创| 国产精品亚洲视频| 欧美一二区视频| 久久男女视频| 91久久精品一区二区三区| 欧美成人午夜剧场免费观看| 亚洲日本一区二区三区| 亚洲一区视频| 国产日本欧美一区二区三区| 久久久www成人免费精品| 欧美成人在线影院| 一区二区三区久久网| 国产精品每日更新在线播放网址| 亚洲欧美在线播放| 久久久久久亚洲精品杨幂换脸| 伊人久久大香线蕉av超碰演员| 另类av导航| 99国产精品久久久久久久| 欧美一级黄色录像| 悠悠资源网久久精品| 欧美精品一区二区在线观看| 亚洲午夜三级在线| 榴莲视频成人在线观看| aa国产精品| 国产一区二区三区黄| 美女尤物久久精品| 亚洲先锋成人| 欧美88av| 午夜欧美不卡精品aaaaa| 国产在线视频不卡二| 欧美精品久久一区| 亚洲欧美一区二区三区在线| 欧美激情精品久久久| 亚洲欧美色一区| 亚洲激情欧美| 国产欧美亚洲一区| 免费人成网站在线观看欧美高清 | 91久久精品国产91久久| 欧美一区二区三区在线观看| 亚洲国产精品成人综合| 国产精品国产a级| 免费亚洲电影在线观看| 一区二区三区成人精品| 欧美成人免费小视频| 羞羞漫画18久久大片| 99re国产精品| 亚洲电影下载| 国产欧美日韩一区二区三区在线| 欧美sm重口味系列视频在线观看| 亚洲自拍另类| 亚洲伦理自拍| 欧美国产大片| 久久久999| 亚洲欧美日韩人成在线播放| 最新中文字幕一区二区三区| 国产综合自拍| 国产欧美日韩一区二区三区在线观看 | 久久久久高清| 亚洲免费视频观看| 一本色道久久综合亚洲精品小说 | 亚洲电影免费观看高清完整版在线观看 | 亚洲精品国产精品国产自| 国产午夜精品久久久久久免费视 | 欧美午夜电影网| 欧美精品一线| 欧美 日韩 国产一区二区在线视频 | 久久理论片午夜琪琪电影网| 亚洲一区亚洲| 亚洲一区二区免费视频| 一区二区免费在线观看| 一本久久综合亚洲鲁鲁| 亚洲精选一区二区| 亚洲欧洲在线视频| 亚洲国产精品久久久久婷婷884| 久久婷婷蜜乳一本欲蜜臀| 久久精品免费播放| 久久都是精品| 久久婷婷蜜乳一本欲蜜臀| 久久女同互慰一区二区三区| 久久久欧美一区二区| 久久久久久久一区二区| 欧美影院成年免费版| 久久国产精品久久国产精品 | 久久精品卡一| 久久久久久久精| 久久综合电影一区| 欧美xart系列高清| 91久久精品久久国产性色也91| 最新成人av网站| 亚洲毛片在线| 亚洲免费一在线| 欧美一区综合| 蜜桃av综合| 欧美日韩精品一区二区三区四区 | 亚洲免费福利视频| 一区二区三区国产在线| 亚洲综合国产激情另类一区| 午夜伦欧美伦电影理论片| 久久狠狠亚洲综合| 欧美成人精品在线播放| 欧美日本高清视频| 国产精品嫩草影院av蜜臀| 国产亚洲午夜| 亚洲清纯自拍| 亚洲欧美另类久久久精品2019| 久久精品国产久精国产爱| 老司机精品导航| 最近看过的日韩成人| 一本色道久久综合亚洲91| 欧美一区国产在线| 免费中文字幕日韩欧美| 国产精品护士白丝一区av| 激情视频一区| 99精品热视频| 久久久久久网| 99综合在线| 久久精品亚洲精品| 欧美视频中文字幕在线| 黄色一区三区| 亚洲男同1069视频| 欧美高清视频| 亚洲女性裸体视频| 欧美电影免费观看高清| 国产午夜精品麻豆| 亚洲视频在线观看免费| 老司机aⅴ在线精品导航| 一区二区三区欧美成人| 麻豆成人在线播放| 国产日韩欧美在线视频观看| aa级大片欧美三级| 蜜臀a∨国产成人精品| 亚洲午夜av在线| 欧美激情va永久在线播放| 国产亚洲综合在线| 亚洲视频在线视频| 亚洲国产成人91精品| 久久aⅴ国产紧身牛仔裤| 国产精品av久久久久久麻豆网| 1000部国产精品成人观看| 欧美一区二区日韩| 99国产精品视频免费观看| 美女国产一区| 在线播放精品| 欧美中文字幕视频| 中文亚洲欧美| 欧美视频一区二区| 亚洲精品一区在线观看| 老色批av在线精品| 久久精品夜色噜噜亚洲a∨| 国产精品一区二区三区四区五区| 中文久久精品| 亚洲全部视频| 欧美极品影院| 亚洲欧洲日本国产| 欧美激情区在线播放| 久久亚洲一区二区三区四区| 国产午夜精品全部视频在线播放| 亚洲欧美大片| 中文欧美字幕免费| 国产精品免费一区二区三区在线观看 | 亚洲午夜在线| 国产精品久久久久永久免费观看 | 日韩一级免费| 亚洲激精日韩激精欧美精品| 欧美成人精品在线观看| 亚洲精品永久免费| 亚洲美女淫视频| 欧美日韩在线播放|