| Example Program Shortest Path in DAGs Computing single source shortest paths in a directed acyclic graph. A tutorial about a shortest path search in a directed acyclic graph.
1 | #include <iostream>
| 2 | #include <seqan/graph_algorithms.h>
| 3 |
| 4 | using namespace seqan;
| 5 |
| 6 | int main() {
| 7 | typedef Graph<Directed<> > TGraph;
| 8 | typedef VertexDescriptor<TGraph>::Type TVertexDescriptor;
| 9 | typedef EdgeDescriptor<TGraph>::Type TEdgeDescriptor;
| 10 | typedef Size<TGraph>::Type TSize;
|
11 | TSize numEdges = 10;
| 12 | TVertexDescriptor edges[] = {0,2, 0,1, 1,3, 1,2, 2,5, 2,4, 2,3, 3,5, 3,4, 4,5};
| 13 | TGraph g;
| 14 | addEdges(g, edges, numEdges);
| 15 | ::std::cout << g << ::std::endl;
|
16 | int weights[] = {3, 5, 6, 2, 2, 4, 7, 1, -1, -2};
| 17 | String<int> weightMap;
| 18 | resizeEdgeMap(g,weightMap, weights);
|
19 | String<unsigned int> predMap;
| 20 | String<unsigned int> distMap;
|
21 | dag_shortest_path(g,1,weightMap,predMap,distMap);
|
22 | ::std::cout << "Single-Source Shortest Paths in DAG: " << ::std::endl;
| 23 | typedef Iterator<TGraph, VertexIterator>::Type TVertexIterator;
| 24 | TVertexIterator it(g);
| 25 | while(!atEnd(it)) {
| 26 | ::std::cout << "Path from 1 to " << getValue(it) << ": ";
| 27 | _print_path(g,predMap,(TVertexDescriptor) 1, getValue(it));
| 28 | ::std::cout << " (Distance: " << getProperty(distMap, getValue(it)) << ")" << ::std::endl;
| 29 | goNext(it);
| 30 | }
| 31 | return 0;
| 32 | }
|
|