src/work/deba/dijkstra.h
changeset 1174 5dccf1916ed8
parent 921 818510fa3d99
equal deleted inserted replaced
2:4e1150fad656 3:c2791a57af6c
    19   ///This class provides an efficient implementation of %Dijkstra algorithm.
    19   ///This class provides an efficient implementation of %Dijkstra algorithm.
    20   ///The edge lengths are passed to the algorithm using a
    20   ///The edge lengths are passed to the algorithm using a
    21   ///\ref ReadMap "readable map",
    21   ///\ref ReadMap "readable map",
    22   ///so it is easy to change it to any kind of length.
    22   ///so it is easy to change it to any kind of length.
    23   ///
    23   ///
    24   ///The type of the length is determined by the \c ValueType of the length map.
    24   ///The type of the length is determined by the \c Value of the length map.
    25   ///
    25   ///
    26   ///It is also possible to change the underlying priority heap.
    26   ///It is also possible to change the underlying priority heap.
    27   ///
    27   ///
    28   ///\param GR The graph type the algorithm runs on.
    28   ///\param GR The graph type the algorithm runs on.
    29   ///\param LM This read-only
    29   ///\param LM This read-only
    57     typedef typename Graph::NodeIt NodeIt;
    57     typedef typename Graph::NodeIt NodeIt;
    58     typedef typename Graph::Edge Edge;
    58     typedef typename Graph::Edge Edge;
    59     typedef typename Graph::OutEdgeIt OutEdgeIt;
    59     typedef typename Graph::OutEdgeIt OutEdgeIt;
    60     
    60     
    61     ///The type of the length of the edges.
    61     ///The type of the length of the edges.
    62     typedef typename LM::ValueType ValueType;
    62     typedef typename LM::Value Value;
    63     ///The type of the map that stores the edge lengths.
    63     ///The type of the map that stores the edge lengths.
    64     typedef LM LengthMap;
    64     typedef LM LengthMap;
    65     ///\brief The type of the map that stores the last
    65     ///\brief The type of the map that stores the last
    66     ///edges of the shortest paths.
    66     ///edges of the shortest paths.
    67     typedef typename Graph::template NodeMap<Edge> PredMap;
    67     typedef typename Graph::template NodeMap<Edge> PredMap;
    68     ///\brief The type of the map that stores the last but one
    68     ///\brief The type of the map that stores the last but one
    69     ///nodes of the shortest paths.
    69     ///nodes of the shortest paths.
    70     typedef typename Graph::template NodeMap<Node> PredNodeMap;
    70     typedef typename Graph::template NodeMap<Node> PredNodeMap;
    71     ///The type of the map that stores the dists of the nodes.
    71     ///The type of the map that stores the dists of the nodes.
    72     typedef typename Graph::template NodeMap<ValueType> DistMap;
    72     typedef typename Graph::template NodeMap<Value> DistMap;
    73 
    73 
    74   private:
    74   private:
    75     const Graph *G;
    75     const Graph *G;
    76     const LM *length;
    76     const LM *length;
    77     //    bool local_length;
    77     //    bool local_length;
   214 	pred_node->set(u,INVALID);
   214 	pred_node->set(u,INVALID);
   215       }
   215       }
   216       
   216       
   217       typename GR::template NodeMap<int> heap_map(*G,-1);
   217       typename GR::template NodeMap<int> heap_map(*G,-1);
   218       
   218       
   219       typedef Heap<Node, ValueType, typename GR::template NodeMap<int>,
   219       typedef Heap<Node, Value, typename GR::template NodeMap<int>,
   220       std::less<ValueType> > 
   220       std::less<Value> > 
   221       HeapType;
   221       HeapType;
   222       
   222       
   223       HeapType heap(heap_map);
   223       HeapType heap(heap_map);
   224       
   224       
   225       heap.push(s,0); 
   225       heap.push(s,0); 
   226       
   226       
   227       while ( !heap.empty() ) {
   227       while ( !heap.empty() ) {
   228 	
   228 	
   229 	Node v=heap.top(); 
   229 	Node v=heap.top(); 
   230 	ValueType oldvalue=heap[v];
   230 	Value oldvalue=heap[v];
   231 	heap.pop();
   231 	heap.pop();
   232 	distance->set(v, oldvalue);
   232 	distance->set(v, oldvalue);
   233 	
   233 	
   234 	
   234 	
   235 	for(OutEdgeIt e(*G,v); G->valid(e); G->next(e)) {
   235 	for(OutEdgeIt e(*G,v); G->valid(e); G->next(e)) {
   259 
   259 
   260     ///Returns the distance of a node from the root.
   260     ///Returns the distance of a node from the root.
   261     ///\pre \ref run() must be called before using this function.
   261     ///\pre \ref run() must be called before using this function.
   262     ///\warning If node \c v in unreachable from the root the return value
   262     ///\warning If node \c v in unreachable from the root the return value
   263     ///of this funcion is undefined.
   263     ///of this funcion is undefined.
   264     ValueType dist(Node v) const { return (*distance)[v]; }
   264     Value dist(Node v) const { return (*distance)[v]; }
   265 
   265 
   266     ///Returns the 'previous edge' of the shortest path tree.
   266     ///Returns the 'previous edge' of the shortest path tree.
   267 
   267 
   268     ///For a node \c v it returns the 'previous edge' of the shortest path tree,
   268     ///For a node \c v it returns the 'previous edge' of the shortest path tree,
   269     ///i.e. it returns the last edge from a shortest path from the root to \c
   269     ///i.e. it returns the last edge from a shortest path from the root to \c