码迷,mamicode.com
首页 > 其他好文 > 详细

求割点 poj 1523

时间:2016-11-12 16:19:30      阅读:153      评论:0      收藏:0      [点我收藏+]

标签:des   双向   i++   namespace   ret   ems   leaves   poj   int   

给你一些双向边 求有多少个割点 并输出去掉点这个点 去掉后有几个联通分量

Tarjan 

 1 #include<stdio.h>
 2 #include<algorithm>
 3 #include<string.h>
 4 #include<queue>
 5 #include<math.h>
 6 
 7 using namespace std;
 8 
 9 #define MAXN 1000
10 int head[MAXN+10],dfn[MAXN+10],low[MAXN+10],z[MAXN+10];
11 int cnt,num;
12 
13 struct edg
14 {
15     int to,next;
16 
17 }x[1000000];
18 
19 void add(int u,int v)
20 {
21     x[cnt].next=head[u];
22     x[cnt].to=v;
23     head[u]=cnt++;
24 }
25 void dfs(int u,int k)
26 {
27     int i;
28     dfn[u]=low[u]=k;
29     for(i=head[u];i!=-1;i=x[i].next)
30     {
31         if(!dfn[x[i].to]) //没访问过 x[i].to孩子节点
32         {
33             dfs(x[i].to,k+1);
34             low[u]=min(low[u],low[x[i].to]);
35             if(low[x[i].to]>=dfn[u]) //不能跳过这个点 去掉后 必然多一个
36                 z[u]++;
37         }
38         else
39             low[u]=min(low[u],dfn[x[i].to]); //访问过 x[i].to 是父亲节点
40     }
41 }
42 int main()
43 {
44     int n,m,ca,m1;
45     ca=1;
46 
47     while(scanf("%d",&n)!=EOF&&n)
48     {
49         m1=0;
50         memset(head,-1,sizeof(head));
51         memset(z,0,sizeof(z));
52         memset(dfn,0,sizeof(dfn));
53         memset(low,0,sizeof(low));
54         scanf("%d",&m);
55         m1=max(n,m);
56         add(n,m),add(m,n);
57 
58         int a,b;
59         while(scanf("%d",&a)!=EOF&&a)
60         {
61             scanf("%d",&b);
62             m1=max(m1,a);
63             m1=max(m1,b);
64             add(a,b),add(b,a);
65         }
66         dfs(1,1); /考虑 1 是根 数组搞出来要减1
67         z[1]--;
68         if(ca!=1)
69             printf("\n");
70         printf("Network #%d\n",ca++);
71         int ok=0;
72 
73         for(int i=1;i<=m1;i++)
74         {
75             if(z[i]>0)
76             {
77                 printf("  SPF node %d leaves %d subnets\n",i,z[i]+1); 去掉该点以下的联通分量 上面还有一半 
78                 ok=1;
79             }
80         }
81         if(ok==0)
82             printf("  No SPF nodes\n");
83     }
84 
85     return 0;
86 }
87 /*
88 Network #1
89   SPF node 3 leaves 2 subnets
90 */

 

求割点 poj 1523

标签:des   双向   i++   namespace   ret   ems   leaves   poj   int   

原文地址:http://www.cnblogs.com/cherryMJY/p/6056722.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!