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

判断一个图中有无环路的存在

时间:2015-08-19 19:59:57      阅读:289      评论:0      收藏:0      [点我收藏+]

标签:

这里要引入两个概念:

1.树边:是一条未被遍历过的边,它指向一个未被访问过的点。

2.反向边:是一条未被遍历过的边,它指向一个被访问过的点。

如果图中有环路的存在,那么环路的最后一个边必然是一条反向边。

我的参考

那么,我们在DFS遍历的过程当中,只需要添加一条语句来判断所有未被检查过的边的指向点是否已被访问过,就可以判断出这个图是否存在环路了。

 

 1 struct Edge {
 2     int to, w, next;
 3 };
 4 
 5 struct adjTable {
 6     int node[maxv];
 7     int visit[maxe];
 8     int cnt;
 9     bool cycle;
10     struct Edge e[maxe];
11     void init() {
12         memset(node, -1, sizeof(node));
13         memset(visit, 0, sizeof(visit));
14         cnt = 0;
15         cycle = false;
16     }
17     void addedge(int u,int v) {
18         e[cnt].to = v;
19         e[cnt].next = node[u];
20         node[u] = cnt++;
21     }
22     void read() {
23         int n, u, v, w;
24         scanf("%d", &n);
25         for (int i=1; i<=n; i++) {
26             scanf("%d %d", &u, &v);
27             addedge(u, v);
28         }
29         return ;
30     }
31     void dfs(int p) {
32         int i;
33         for (i=node[p]; i!=-1; i=e[i].next) {
34             if ( visit[e[i].to] )//判断第i条边是否为反向边
35                 cycle = true; //dfs运行之后就可以根据cycle的true还是false来判断环路是否存在了
36             if (visit[ e[i].to ] == 0) {
37                 printf("%d %d\n", p, e[i].to);
38                 visit[ p ] = 1;
39                 dfs( e[i].to );
40             }
41         }
42     }
43 };

 

判断一个图中有无环路的存在

标签:

原文地址:http://www.cnblogs.com/marginalman/p/4742704.html

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