• <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>

            POJ 1523 SPF 割點+分割連通塊的數量

            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


                圖論,又是一道割點的題,并且還要求出圖中所有的割點分別能將圖分割成幾個不同的塊??梢詫⒛硞€割點的訪問標記設置為1,然后對圖進行dfs,方法類似求圖中有幾個連通的區域。
            #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 極限定律 閱讀(1099) 評論(0)  編輯 收藏 引用 所屬分類: ACM/ICPC

            <2009年5月>
            262728293012
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            導航

            統計

            常用鏈接

            留言簿(10)

            隨筆分類

            隨筆檔案

            友情鏈接

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            久久99精品国产麻豆| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 伊人久久无码中文字幕| 精品国产乱码久久久久软件| 久久久久久国产精品无码超碰| 久久电影网一区| 精品国产青草久久久久福利| 日韩一区二区久久久久久| 一本色道久久综合狠狠躁篇| 99国产欧美精品久久久蜜芽| 无码精品久久一区二区三区| 久久99精品综合国产首页| 久久人人爽人人爽人人片AV东京热 | 国产精品久久久久9999高清| 久久久久亚洲AV成人网人人软件| 色偷偷88888欧美精品久久久 | 精品久久久中文字幕人妻| 久久精品国产一区二区电影| 久久久久99精品成人片欧美| 思思久久99热只有频精品66| 99久久亚洲综合精品网站| 国产成人久久精品一区二区三区| 欧美亚洲国产精品久久久久| 久久精品亚洲乱码伦伦中文| 久久久国产精品福利免费 | 亚洲人成无码网站久久99热国产| 91久久精品无码一区二区毛片| 久久A级毛片免费观看| 久久精品亚洲日本波多野结衣| 久久国产色av免费看| 久久中文字幕人妻丝袜| 日本五月天婷久久网站| 欧美国产成人久久精品| 中文成人久久久久影院免费观看 | 亚洲欧美一级久久精品| 亚洲欧美另类日本久久国产真实乱对白| 四虎国产精品免费久久久| 青青草原综合久久| 狠狠色伊人久久精品综合网| 久久久久久久综合综合狠狠| 伊人久久大香线蕉AV一区二区|