demo/dijkstra_demo.cc
changeset 1711 1d09b48e8d55
parent 1636 260ac104190f
child 1715 e71778873dd0
equal deleted inserted replaced
6:b4366d219515 7:d41047ef31bc
    20 ///
    20 ///
    21 /// Dijkstra's algorithm computes shortest paths between two nodes in
    21 /// Dijkstra's algorithm computes shortest paths between two nodes in
    22 /// a graph with edge lengths. Here we only show some of the
    22 /// a graph with edge lengths. Here we only show some of the
    23 /// facilities supplied by our implementation: for the detailed
    23 /// facilities supplied by our implementation: for the detailed
    24 /// documentation of the LEMON Dijkstra class read \ref lemon::Dijkstra "this".
    24 /// documentation of the LEMON Dijkstra class read \ref lemon::Dijkstra "this".
       
    25 ///
       
    26 /// \include dijkstra_demo.cc
    25 
    27 
    26 #include <iostream>
    28 #include <iostream>
    27 
    29 
    28 #include <lemon/list_graph.h>
    30 #include <lemon/list_graph.h>
    29 #include <lemon/dijkstra.h>
    31 #include <lemon/dijkstra.h>
    30 //#include <lemon/graph_writer.h>
       
    31 
    32 
    32 using namespace lemon;
    33 using namespace lemon;
    33 
    34 
    34 
    35 
    35 int main (int, char*[])
    36 int main (int, char*[])
    67     len.set(v2_v5, 8);
    68     len.set(v2_v5, 8);
    68     len.set(v3_v5, 5);
    69     len.set(v3_v5, 5);
    69     len.set(v4_t, 8);
    70     len.set(v4_t, 8);
    70     len.set(v5_t, 8);
    71     len.set(v5_t, 8);
    71 
    72 
    72     std::cout << "This program is a simple demo of the LEMON Dijkstra class."<<std::endl;
    73     std::cout << "This program is a simple demo of the LEMON Dijkstra class."
    73     std::cout << "We calculate the shortest path from node s to node t in a graph."<<std::endl;
    74 	      << std::endl;
    74     std::cout <<std::endl;
    75     std::cout <<
       
    76       "We calculate the shortest path from node s to node t in a graph."
       
    77 	      << std::endl;
       
    78     std::cout << std::endl;
    75 
    79 
    76 
    80 
    77     std::cout << "The id of s is " << g.id(s)<< ", the id of t is " << g.id(t)<<"."<<std::endl;
    81     std::cout << "The id of s is " << g.id(s)<< ", the id of t is "
       
    82 	      << g.id(t) << "." << std::endl;
    78 
    83 
    79     std::cout << "Dijkstra algorithm demo..." << std::endl;
    84     std::cout << "Dijkstra algorithm demo..." << std::endl;
    80 
       
    81 
    85 
    82     Dijkstra<Graph, LengthMap> dijkstra_test(g,len);
    86     Dijkstra<Graph, LengthMap> dijkstra_test(g,len);
    83     
    87     
    84     dijkstra_test.run(s);
    88     dijkstra_test.run(s);
       
    89     
       
    90     std::cout << "The distance of node t from node s: "
       
    91 	      << dijkstra_test.dist(t) << std::endl;
    85 
    92 
       
    93     std::cout << "The shortest path from s to t goes through the following "
       
    94 	      << "nodes (the first one is t, the last one is s): "
       
    95 	      << std::endl;
       
    96 
       
    97     for (Node v=t;v != s; v=dijkstra_test.predNode(v)) {
       
    98       std::cout << g.id(v) << "<-";
       
    99     }
    86     
   100     
    87     std::cout << "The distance of node t from node s: " << dijkstra_test.dist(t)<<std::endl;
       
    88 
       
    89     std::cout << "The shortest path from s to t goes through the following nodes (the first one is t, the last one is s): "<<std::endl;
       
    90 
       
    91     for (Node v=t;v != s; v=dijkstra_test.predNode(v)){
       
    92 	std::cout << g.id(v) << "<-";
       
    93     }
       
    94     std::cout << g.id(s) << std::endl;	
   101     std::cout << g.id(s) << std::endl;	
    95     
   102     
    96 
       
    97     return 0;
   103     return 0;
    98 }
   104 }
    99 
       
   100 
       
   101 
       
   102 
       
   103 
       
   104 
       
   105 
       
   106 
       
   107