首页 > Web开发 > 详细

POJ 1236 Network of Schools

时间:2017-03-09 18:45:47      阅读:249      评论:0      收藏:0      [点我收藏+]

传送门:http://poj.org/problem?id=1236

技术分享

技术分享

实现代码:

  1 #include <cstdio>
  2 #include <algorithm>
  3 #include <cstring>
  4 #include <map>
  5 using namespace std;
  6 
  7 const int MAXN=10010;
  8 const int MAXM=50010;
  9 
 10 struct Edge{
 11     int to;
 12     int next;
 13 }edge[MAXM];
 14 
 15 int head[MAXN];
 16 int tot;
 17 
 18 void addEdge(int u,int v){
 19     edge[tot].to=v;
 20     edge[tot].next=head[u];
 21     head[u]=tot++;
 22 }
 23 
 24 void init(){
 25     memset(head,-1,sizeof(head));
 26     tot=0;
 27 }
 28 
 29 int LOW[MAXN],DFS[MAXN],Stack[MAXN],Num[MAXN],Belong[MAXN];
 30 bool Instack[MAXN];
 31 int Index;
 32 int scc;
 33 int top;
 34 
 35 void Targan(int u){
 36     LOW[u]=DFS[u]=++Index;
 37     Stack[top++]=u;
 38     Instack[u]=true;
 39 
 40     int v;
 41     for(int i=head[u];i!=-1;i=edge[i].next){
 42         v=edge[i].to;
 43         if(!DFS[v]){
 44             Targan(v);
 45             if(LOW[u]>LOW[v])
 46                 LOW[u]=LOW[v];
 47         }else if(Instack[v]&&LOW[u]>DFS[v]){
 48                 LOW[u]=DFS[v];
 49         }
 50     }
 51 
 52     if(LOW[u]==DFS[u]){
 53         scc++;
 54 
 55         do{
 56             v=Stack[--top];
 57             Instack[v]=false;
 58             Belong[v]=scc;
 59             Num[scc]++;
 60         }while(v!=u);
 61     }
 62 }
 63 
 64 void Solve(int n){
 65     memset(Instack,false,sizeof(Instack));
 66     memset(DFS,0,sizeof(DFS));
 67     memset(Num,0,sizeof(Num));
 68 
 69     Index=scc=top=0;
 70     for(int i=1;i<=n;i++)
 71         if(!DFS[i])
 72         Targan(i);
 73 }
 74 
 75 map<int,int>mp[MAXN];
 76 int out[MAXN],in[MAXN];
 77 int main(){
 78     int n;
 79     while(scanf("%d",&n)!=EOF){
 80         init();
 81 
 82         for(int i=1;i<=n;i++){
 83             int v;
 84             while(scanf("%d",&v)&&v){
 85                 addEdge(i,v);
 86                 mp[i][v]=1;
 87             }
 88         }
 89         Solve(n);
 90          if(scc==1){
 91             printf("1\n0\n");
 92             continue;
 93         }
 94 
 95         for(int i=1;i<=n;i++)
 96         for(int j=1;j<=n;j++){
 97             if(mp[i][j]&&Belong[i]!=Belong[j]){
 98                 out[Belong[i]]++;
 99                 in[Belong[j]]++;
100             }
101         }
102 
103         int ans1=0,ans2=0;
104         for(int i=1;i<=scc;i++){
105             if(in[i]==0) ans1++;
106             if(out[i]==0) ans2++;
107         }
108 
109         printf("%d\n%d\n",ans1,max(ans1,ans2));
110 
111 
112     }
113 }

 

POJ 1236 Network of Schools

原文:http://www.cnblogs.com/IKnowYou0/p/6526916.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!