data:image/s3,"s3://crabby-images/8e977/8e977bd648dfe94e3459c0bf808ce57578799d0e" alt=""
I wonder if someone knows an easy way to detect cycles in a graph. Any suggestion welcome ;) NC
data:image/s3,"s3://crabby-images/d8bda/d8bda3d2eed508878ff44ed9b26193c8235d38f9" alt=""
You could tag each vertex or edge with a "visited" flag. Set "visited" to false initially. Then use a traversal algorithm to traverse the graph, starting at any vertex or edge. When each vertex or edge gets visited, check the state of the "visited" flag. If true, then stop because there is a cycle, because there is more than one route to that vertex or edge. If it's false, set it to true, and move on to the next vertex or edge. Regards, Markus. Chartier Nicolas wrote:
I wonder if someone knows an easy way to detect cycles in a graph. Any suggestion welcome ;)
NC
_______________________________________________ Boost-users mailing list Boost-users@lists.boost.org http://lists.boost.org/mailman/listinfo.cgi/boost-users
data:image/s3,"s3://crabby-images/7c557/7c557d35d61ef5339affc61b3d8c138dbec11e58" alt=""
Yep, Depth First Search: http://www.boost.org/doc/libs/1_35_0/libs/graph/doc/file_dependency_example.... :cycles Cheers, James. On 16 Apr 2008, at 21:53, Chartier Nicolas wrote:
I wonder if someone knows an easy way to detect cycles in a graph. Any suggestion welcome ;)
NC
_______________________________________________ Boost-users mailing list Boost-users@lists.boost.org http://lists.boost.org/mailman/listinfo.cgi/boost-users
data:image/s3,"s3://crabby-images/1f8b3/1f8b3b3581e892274810b737bc0456bcc63f5e54" alt=""
In most cases if you ask how to find cycles you really mean 'how to find strongly connected components' : http://en.wikipedia.org/wiki/Strongly_connected_component think it over... Cheers, Michał Nowotka
participants (4)
-
Chartier Nicolas
-
James Jackson
-
Markus Svilans
-
Michał Nowotka