hdu 3342 Legal or Not(拓扑排序) HDOJ Monthly Contest – 2010.03.06

一道极其水的拓扑排序……但是我还是要把它发出来,原因很简单,连错12次……

题意也很裸,前面的废话不用看,直接看输入

输入n, m表示从0到n-1共n个人,有m组关系

截下来m组,每组输入a, b表示a指向b,或者b指向a也行。

输入n == 0时结束

如果可以拓扑排序,输出"YES",否则输出"NO"。每组输出占一行。

给两种代码吧,一种用邻接矩阵,另一种我也不知道叫什么好……

邻接矩阵——

 1 #include <cstdio>
 2 #include <cstring>
 3 #include <cmath>
 4 #include <algorithm>
 5 #include <queue>
 6 using namespace std;
 7 
 8 const int N = 110;
 9 
10 int mp[N][N];
11 int n, m;
12 int a, b;
13 int dg[N];
14 
15 int main()
16 {
17     //freopen("test.txt", "r", stdin);
18     while(~scanf("%d%d", &n, &m) && n)
19     {
20         memset(dg, 0, sizeof(dg));
21         memset(mp, 0, sizeof(mp));
22         for(int i = 0; i < m; i++)
23         {
24             scanf("%d%d", &a, &b);
25             if(mp[a][b] == 0 && a != b)
26             {
27                 dg[b]++;
28                 mp[a][b] = 1;
29             }
30         }
31 
32         queue<int> que;
33         for(int i = 0; i < n; i++)
34         {
35             if(!dg[i]) que.push(i);
36         }
37 
38         int sum = 0;
39         while(!que.empty())
40         {
41             int p = que.front();
42             que.pop();
43             sum++;
44             dg[p]--;
45             for(int i = 0; i < n; i++)
46             {
47                 if(mp[p][i])
48                 {
49                     dg[i]--;
50                     if(!dg[i])
51                     {
52                         que.push(i);
53                     }
54                 }
55 
56             }
57         }
58         if(sum == n) printf("YES\n");
59         else printf("NO\n");
60 
61     }
62     return 0;
63 }

不知名——

 1 #include <cstdio>
 2 #include <cstring>
 3 #include <cmath>
 4 #include <algorithm>
 5 #include <queue>
 6 using namespace std;
 7 
 8 const int N = 110;
 9 
10 struct Node
11 {
12     int to;
13     int next;
14 }node[N];
15 
16 int head[N];
17 int dg[N];
18 int n, m;
19 int a, b;
20 
21 int main()
22 {
23     //freopen("test.txt", "r", stdin);
24     while(~scanf("%d%d", &n, &m) && n)
25     {
26         memset(head, -1, sizeof(head));
27         memset(dg, 0, sizeof(dg));
28         for(int i = 0; i < m; i++)
29         {
30             scanf("%d%d", &a, &b);
31             node[i].to = b;
32             node[i].next = head[a];
33             head[a] = i;
34             dg[b]++;
35         }
36 
37         int sum = 0;
38         queue<int>que;
39         for(int i = 0; i < n; i++)
40         {
41             if(!dg[i])
42             {
43                 que.push(i);
44             }
45         }
46 
47         while(!que.empty())
48         {
49             int p = que.front();
50             que.pop();
51             dg[p]--;
52             sum++;
53             for(int i = head[p]; i != -1; i = node[i].next)
54             {
55                 int v = node[i].to;
56                 dg[v]--;
57                 if(!dg[v])
58                 {
59                     que.push(v);
60                 }
61             }
62         }
63         if(sum == n) printf("YES\n");
64         else printf("NO\n");
65     }
66     return 0;
67 }

 知道名字了,叫前向星标……

posted @ 2015-05-05 23:49  mypride  阅读(162)  评论(0编辑  收藏  举报