lemon/dfs.h
author Alpar Juttner <alpar@cs.elte.hu>
Fri, 20 Jul 2012 21:23:17 +0200
changeset 1015 d32e4453b48c
parent 959 17e36e175725
child 976 426a704d7483
child 998 7fdaa05a69a1
permissions -rw-r--r--
Fix missing initialization in CplexEnv::CplexEnv() (#445)
     1 /* -*- mode: C++; indent-tabs-mode: nil; -*-
     2  *
     3  * This file is a part of LEMON, a generic C++ optimization library.
     4  *
     5  * Copyright (C) 2003-2009
     6  * Egervary Jeno Kombinatorikus Optimalizalasi Kutatocsoport
     7  * (Egervary Research Group on Combinatorial Optimization, EGRES).
     8  *
     9  * Permission to use, modify and distribute this software is granted
    10  * provided that this copyright notice appears in all copies. For
    11  * precise terms see the accompanying LICENSE file.
    12  *
    13  * This software is provided "AS IS" with no warranty of any kind,
    14  * express or implied, and with no claim as to its suitability for any
    15  * purpose.
    16  *
    17  */
    18 
    19 #ifndef LEMON_DFS_H
    20 #define LEMON_DFS_H
    21 
    22 ///\ingroup search
    23 ///\file
    24 ///\brief DFS algorithm.
    25 
    26 #include <lemon/list_graph.h>
    27 #include <lemon/bits/path_dump.h>
    28 #include <lemon/core.h>
    29 #include <lemon/error.h>
    30 #include <lemon/maps.h>
    31 #include <lemon/path.h>
    32 
    33 namespace lemon {
    34 
    35   ///Default traits class of Dfs class.
    36 
    37   ///Default traits class of Dfs class.
    38   ///\tparam GR Digraph type.
    39   template<class GR>
    40   struct DfsDefaultTraits
    41   {
    42     ///The type of the digraph the algorithm runs on.
    43     typedef GR Digraph;
    44 
    45     ///\brief The type of the map that stores the predecessor
    46     ///arcs of the %DFS paths.
    47     ///
    48     ///The type of the map that stores the predecessor
    49     ///arcs of the %DFS paths.
    50     ///It must meet the \ref concepts::WriteMap "WriteMap" concept.
    51     typedef typename Digraph::template NodeMap<typename Digraph::Arc> PredMap;
    52     ///Instantiates a \c PredMap.
    53 
    54     ///This function instantiates a \ref PredMap.
    55     ///\param g is the digraph, to which we would like to define the
    56     ///\ref PredMap.
    57     static PredMap *createPredMap(const Digraph &g)
    58     {
    59       return new PredMap(g);
    60     }
    61 
    62     ///The type of the map that indicates which nodes are processed.
    63 
    64     ///The type of the map that indicates which nodes are processed.
    65     ///It must meet the \ref concepts::WriteMap "WriteMap" concept.
    66     typedef NullMap<typename Digraph::Node,bool> ProcessedMap;
    67     ///Instantiates a \c ProcessedMap.
    68 
    69     ///This function instantiates a \ref ProcessedMap.
    70     ///\param g is the digraph, to which
    71     ///we would like to define the \ref ProcessedMap.
    72 #ifdef DOXYGEN
    73     static ProcessedMap *createProcessedMap(const Digraph &g)
    74 #else
    75     static ProcessedMap *createProcessedMap(const Digraph &)
    76 #endif
    77     {
    78       return new ProcessedMap();
    79     }
    80 
    81     ///The type of the map that indicates which nodes are reached.
    82 
    83     ///The type of the map that indicates which nodes are reached.
    84     ///It must meet the \ref concepts::ReadWriteMap "ReadWriteMap" concept.
    85     typedef typename Digraph::template NodeMap<bool> ReachedMap;
    86     ///Instantiates a \c ReachedMap.
    87 
    88     ///This function instantiates a \ref ReachedMap.
    89     ///\param g is the digraph, to which
    90     ///we would like to define the \ref ReachedMap.
    91     static ReachedMap *createReachedMap(const Digraph &g)
    92     {
    93       return new ReachedMap(g);
    94     }
    95 
    96     ///The type of the map that stores the distances of the nodes.
    97 
    98     ///The type of the map that stores the distances of the nodes.
    99     ///It must meet the \ref concepts::WriteMap "WriteMap" concept.
   100     typedef typename Digraph::template NodeMap<int> DistMap;
   101     ///Instantiates a \c DistMap.
   102 
   103     ///This function instantiates a \ref DistMap.
   104     ///\param g is the digraph, to which we would like to define the
   105     ///\ref DistMap.
   106     static DistMap *createDistMap(const Digraph &g)
   107     {
   108       return new DistMap(g);
   109     }
   110   };
   111 
   112   ///%DFS algorithm class.
   113 
   114   ///\ingroup search
   115   ///This class provides an efficient implementation of the %DFS algorithm.
   116   ///
   117   ///There is also a \ref dfs() "function-type interface" for the DFS
   118   ///algorithm, which is convenient in the simplier cases and it can be
   119   ///used easier.
   120   ///
   121   ///\tparam GR The type of the digraph the algorithm runs on.
   122   ///The default type is \ref ListDigraph.
   123 #ifdef DOXYGEN
   124   template <typename GR,
   125             typename TR>
   126 #else
   127   template <typename GR=ListDigraph,
   128             typename TR=DfsDefaultTraits<GR> >
   129 #endif
   130   class Dfs {
   131   public:
   132 
   133     ///The type of the digraph the algorithm runs on.
   134     typedef typename TR::Digraph Digraph;
   135 
   136     ///\brief The type of the map that stores the predecessor arcs of the
   137     ///DFS paths.
   138     typedef typename TR::PredMap PredMap;
   139     ///The type of the map that stores the distances of the nodes.
   140     typedef typename TR::DistMap DistMap;
   141     ///The type of the map that indicates which nodes are reached.
   142     typedef typename TR::ReachedMap ReachedMap;
   143     ///The type of the map that indicates which nodes are processed.
   144     typedef typename TR::ProcessedMap ProcessedMap;
   145     ///The type of the paths.
   146     typedef PredMapPath<Digraph, PredMap> Path;
   147 
   148     ///The \ref DfsDefaultTraits "traits class" of the algorithm.
   149     typedef TR Traits;
   150 
   151   private:
   152 
   153     typedef typename Digraph::Node Node;
   154     typedef typename Digraph::NodeIt NodeIt;
   155     typedef typename Digraph::Arc Arc;
   156     typedef typename Digraph::OutArcIt OutArcIt;
   157 
   158     //Pointer to the underlying digraph.
   159     const Digraph *G;
   160     //Pointer to the map of predecessor arcs.
   161     PredMap *_pred;
   162     //Indicates if _pred is locally allocated (true) or not.
   163     bool local_pred;
   164     //Pointer to the map of distances.
   165     DistMap *_dist;
   166     //Indicates if _dist is locally allocated (true) or not.
   167     bool local_dist;
   168     //Pointer to the map of reached status of the nodes.
   169     ReachedMap *_reached;
   170     //Indicates if _reached is locally allocated (true) or not.
   171     bool local_reached;
   172     //Pointer to the map of processed status of the nodes.
   173     ProcessedMap *_processed;
   174     //Indicates if _processed is locally allocated (true) or not.
   175     bool local_processed;
   176 
   177     std::vector<typename Digraph::OutArcIt> _stack;
   178     int _stack_head;
   179 
   180     //Creates the maps if necessary.
   181     void create_maps()
   182     {
   183       if(!_pred) {
   184         local_pred = true;
   185         _pred = Traits::createPredMap(*G);
   186       }
   187       if(!_dist) {
   188         local_dist = true;
   189         _dist = Traits::createDistMap(*G);
   190       }
   191       if(!_reached) {
   192         local_reached = true;
   193         _reached = Traits::createReachedMap(*G);
   194       }
   195       if(!_processed) {
   196         local_processed = true;
   197         _processed = Traits::createProcessedMap(*G);
   198       }
   199     }
   200 
   201   protected:
   202 
   203     Dfs() {}
   204 
   205   public:
   206 
   207     typedef Dfs Create;
   208 
   209     ///\name Named Template Parameters
   210 
   211     ///@{
   212 
   213     template <class T>
   214     struct SetPredMapTraits : public Traits {
   215       typedef T PredMap;
   216       static PredMap *createPredMap(const Digraph &)
   217       {
   218         LEMON_ASSERT(false, "PredMap is not initialized");
   219         return 0; // ignore warnings
   220       }
   221     };
   222     ///\brief \ref named-templ-param "Named parameter" for setting
   223     ///\c PredMap type.
   224     ///
   225     ///\ref named-templ-param "Named parameter" for setting
   226     ///\c PredMap type.
   227     ///It must meet the \ref concepts::WriteMap "WriteMap" concept.
   228     template <class T>
   229     struct SetPredMap : public Dfs<Digraph, SetPredMapTraits<T> > {
   230       typedef Dfs<Digraph, SetPredMapTraits<T> > Create;
   231     };
   232 
   233     template <class T>
   234     struct SetDistMapTraits : public Traits {
   235       typedef T DistMap;
   236       static DistMap *createDistMap(const Digraph &)
   237       {
   238         LEMON_ASSERT(false, "DistMap is not initialized");
   239         return 0; // ignore warnings
   240       }
   241     };
   242     ///\brief \ref named-templ-param "Named parameter" for setting
   243     ///\c DistMap type.
   244     ///
   245     ///\ref named-templ-param "Named parameter" for setting
   246     ///\c DistMap type.
   247     ///It must meet the \ref concepts::WriteMap "WriteMap" concept.
   248     template <class T>
   249     struct SetDistMap : public Dfs< Digraph, SetDistMapTraits<T> > {
   250       typedef Dfs<Digraph, SetDistMapTraits<T> > Create;
   251     };
   252 
   253     template <class T>
   254     struct SetReachedMapTraits : public Traits {
   255       typedef T ReachedMap;
   256       static ReachedMap *createReachedMap(const Digraph &)
   257       {
   258         LEMON_ASSERT(false, "ReachedMap is not initialized");
   259         return 0; // ignore warnings
   260       }
   261     };
   262     ///\brief \ref named-templ-param "Named parameter" for setting
   263     ///\c ReachedMap type.
   264     ///
   265     ///\ref named-templ-param "Named parameter" for setting
   266     ///\c ReachedMap type.
   267     ///It must meet the \ref concepts::ReadWriteMap "ReadWriteMap" concept.
   268     template <class T>
   269     struct SetReachedMap : public Dfs< Digraph, SetReachedMapTraits<T> > {
   270       typedef Dfs< Digraph, SetReachedMapTraits<T> > Create;
   271     };
   272 
   273     template <class T>
   274     struct SetProcessedMapTraits : public Traits {
   275       typedef T ProcessedMap;
   276       static ProcessedMap *createProcessedMap(const Digraph &)
   277       {
   278         LEMON_ASSERT(false, "ProcessedMap is not initialized");
   279         return 0; // ignore warnings
   280       }
   281     };
   282     ///\brief \ref named-templ-param "Named parameter" for setting
   283     ///\c ProcessedMap type.
   284     ///
   285     ///\ref named-templ-param "Named parameter" for setting
   286     ///\c ProcessedMap type.
   287     ///It must meet the \ref concepts::WriteMap "WriteMap" concept.
   288     template <class T>
   289     struct SetProcessedMap : public Dfs< Digraph, SetProcessedMapTraits<T> > {
   290       typedef Dfs< Digraph, SetProcessedMapTraits<T> > Create;
   291     };
   292 
   293     struct SetStandardProcessedMapTraits : public Traits {
   294       typedef typename Digraph::template NodeMap<bool> ProcessedMap;
   295       static ProcessedMap *createProcessedMap(const Digraph &g)
   296       {
   297         return new ProcessedMap(g);
   298       }
   299     };
   300     ///\brief \ref named-templ-param "Named parameter" for setting
   301     ///\c ProcessedMap type to be <tt>Digraph::NodeMap<bool></tt>.
   302     ///
   303     ///\ref named-templ-param "Named parameter" for setting
   304     ///\c ProcessedMap type to be <tt>Digraph::NodeMap<bool></tt>.
   305     ///If you don't set it explicitly, it will be automatically allocated.
   306     struct SetStandardProcessedMap :
   307       public Dfs< Digraph, SetStandardProcessedMapTraits > {
   308       typedef Dfs< Digraph, SetStandardProcessedMapTraits > Create;
   309     };
   310 
   311     ///@}
   312 
   313   public:
   314 
   315     ///Constructor.
   316 
   317     ///Constructor.
   318     ///\param g The digraph the algorithm runs on.
   319     Dfs(const Digraph &g) :
   320       G(&g),
   321       _pred(NULL), local_pred(false),
   322       _dist(NULL), local_dist(false),
   323       _reached(NULL), local_reached(false),
   324       _processed(NULL), local_processed(false)
   325     { }
   326 
   327     ///Destructor.
   328     ~Dfs()
   329     {
   330       if(local_pred) delete _pred;
   331       if(local_dist) delete _dist;
   332       if(local_reached) delete _reached;
   333       if(local_processed) delete _processed;
   334     }
   335 
   336     ///Sets the map that stores the predecessor arcs.
   337 
   338     ///Sets the map that stores the predecessor arcs.
   339     ///If you don't use this function before calling \ref run(Node) "run()"
   340     ///or \ref init(), an instance will be allocated automatically.
   341     ///The destructor deallocates this automatically allocated map,
   342     ///of course.
   343     ///\return <tt> (*this) </tt>
   344     Dfs &predMap(PredMap &m)
   345     {
   346       if(local_pred) {
   347         delete _pred;
   348         local_pred=false;
   349       }
   350       _pred = &m;
   351       return *this;
   352     }
   353 
   354     ///Sets the map that indicates which nodes are reached.
   355 
   356     ///Sets the map that indicates which nodes are reached.
   357     ///If you don't use this function before calling \ref run(Node) "run()"
   358     ///or \ref init(), an instance will be allocated automatically.
   359     ///The destructor deallocates this automatically allocated map,
   360     ///of course.
   361     ///\return <tt> (*this) </tt>
   362     Dfs &reachedMap(ReachedMap &m)
   363     {
   364       if(local_reached) {
   365         delete _reached;
   366         local_reached=false;
   367       }
   368       _reached = &m;
   369       return *this;
   370     }
   371 
   372     ///Sets the map that indicates which nodes are processed.
   373 
   374     ///Sets the map that indicates which nodes are processed.
   375     ///If you don't use this function before calling \ref run(Node) "run()"
   376     ///or \ref init(), an instance will be allocated automatically.
   377     ///The destructor deallocates this automatically allocated map,
   378     ///of course.
   379     ///\return <tt> (*this) </tt>
   380     Dfs &processedMap(ProcessedMap &m)
   381     {
   382       if(local_processed) {
   383         delete _processed;
   384         local_processed=false;
   385       }
   386       _processed = &m;
   387       return *this;
   388     }
   389 
   390     ///Sets the map that stores the distances of the nodes.
   391 
   392     ///Sets the map that stores the distances of the nodes calculated by
   393     ///the algorithm.
   394     ///If you don't use this function before calling \ref run(Node) "run()"
   395     ///or \ref init(), an instance will be allocated automatically.
   396     ///The destructor deallocates this automatically allocated map,
   397     ///of course.
   398     ///\return <tt> (*this) </tt>
   399     Dfs &distMap(DistMap &m)
   400     {
   401       if(local_dist) {
   402         delete _dist;
   403         local_dist=false;
   404       }
   405       _dist = &m;
   406       return *this;
   407     }
   408 
   409   public:
   410 
   411     ///\name Execution Control
   412     ///The simplest way to execute the DFS algorithm is to use one of the
   413     ///member functions called \ref run(Node) "run()".\n
   414     ///If you need more control on the execution, first you have to call
   415     ///\ref init(), then you can add a source node with \ref addSource()
   416     ///and perform the actual computation with \ref start().
   417     ///This procedure can be repeated if there are nodes that have not
   418     ///been reached.
   419 
   420     ///@{
   421 
   422     ///\brief Initializes the internal data structures.
   423     ///
   424     ///Initializes the internal data structures.
   425     void init()
   426     {
   427       create_maps();
   428       _stack.resize(countNodes(*G));
   429       _stack_head=-1;
   430       for ( NodeIt u(*G) ; u!=INVALID ; ++u ) {
   431         _pred->set(u,INVALID);
   432         _reached->set(u,false);
   433         _processed->set(u,false);
   434       }
   435     }
   436 
   437     ///Adds a new source node.
   438 
   439     ///Adds a new source node to the set of nodes to be processed.
   440     ///
   441     ///\pre The stack must be empty. Otherwise the algorithm gives
   442     ///wrong results. (One of the outgoing arcs of all the source nodes
   443     ///except for the last one will not be visited and distances will
   444     ///also be wrong.)
   445     void addSource(Node s)
   446     {
   447       LEMON_DEBUG(emptyQueue(), "The stack is not empty.");
   448       if(!(*_reached)[s])
   449         {
   450           _reached->set(s,true);
   451           _pred->set(s,INVALID);
   452           OutArcIt e(*G,s);
   453           if(e!=INVALID) {
   454             _stack[++_stack_head]=e;
   455             _dist->set(s,_stack_head);
   456           }
   457           else {
   458             _processed->set(s,true);
   459             _dist->set(s,0);
   460           }
   461         }
   462     }
   463 
   464     ///Processes the next arc.
   465 
   466     ///Processes the next arc.
   467     ///
   468     ///\return The processed arc.
   469     ///
   470     ///\pre The stack must not be empty.
   471     Arc processNextArc()
   472     {
   473       Node m;
   474       Arc e=_stack[_stack_head];
   475       if(!(*_reached)[m=G->target(e)]) {
   476         _pred->set(m,e);
   477         _reached->set(m,true);
   478         ++_stack_head;
   479         _stack[_stack_head] = OutArcIt(*G, m);
   480         _dist->set(m,_stack_head);
   481       }
   482       else {
   483         m=G->source(e);
   484         ++_stack[_stack_head];
   485       }
   486       while(_stack_head>=0 && _stack[_stack_head]==INVALID) {
   487         _processed->set(m,true);
   488         --_stack_head;
   489         if(_stack_head>=0) {
   490           m=G->source(_stack[_stack_head]);
   491           ++_stack[_stack_head];
   492         }
   493       }
   494       return e;
   495     }
   496 
   497     ///Next arc to be processed.
   498 
   499     ///Next arc to be processed.
   500     ///
   501     ///\return The next arc to be processed or \c INVALID if the stack
   502     ///is empty.
   503     OutArcIt nextArc() const
   504     {
   505       return _stack_head>=0?_stack[_stack_head]:INVALID;
   506     }
   507 
   508     ///Returns \c false if there are nodes to be processed.
   509 
   510     ///Returns \c false if there are nodes to be processed
   511     ///in the queue (stack).
   512     bool emptyQueue() const { return _stack_head<0; }
   513 
   514     ///Returns the number of the nodes to be processed.
   515 
   516     ///Returns the number of the nodes to be processed
   517     ///in the queue (stack).
   518     int queueSize() const { return _stack_head+1; }
   519 
   520     ///Executes the algorithm.
   521 
   522     ///Executes the algorithm.
   523     ///
   524     ///This method runs the %DFS algorithm from the root node
   525     ///in order to compute the DFS path to each node.
   526     ///
   527     /// The algorithm computes
   528     ///- the %DFS tree,
   529     ///- the distance of each node from the root in the %DFS tree.
   530     ///
   531     ///\pre init() must be called and a root node should be
   532     ///added with addSource() before using this function.
   533     ///
   534     ///\note <tt>d.start()</tt> is just a shortcut of the following code.
   535     ///\code
   536     ///  while ( !d.emptyQueue() ) {
   537     ///    d.processNextArc();
   538     ///  }
   539     ///\endcode
   540     void start()
   541     {
   542       while ( !emptyQueue() ) processNextArc();
   543     }
   544 
   545     ///Executes the algorithm until the given target node is reached.
   546 
   547     ///Executes the algorithm until the given target node is reached.
   548     ///
   549     ///This method runs the %DFS algorithm from the root node
   550     ///in order to compute the DFS path to \c t.
   551     ///
   552     ///The algorithm computes
   553     ///- the %DFS path to \c t,
   554     ///- the distance of \c t from the root in the %DFS tree.
   555     ///
   556     ///\pre init() must be called and a root node should be
   557     ///added with addSource() before using this function.
   558     void start(Node t)
   559     {
   560       while ( !emptyQueue() && !(*_reached)[t] )
   561         processNextArc();
   562     }
   563 
   564     ///Executes the algorithm until a condition is met.
   565 
   566     ///Executes the algorithm until a condition is met.
   567     ///
   568     ///This method runs the %DFS algorithm from the root node
   569     ///until an arc \c a with <tt>am[a]</tt> true is found.
   570     ///
   571     ///\param am A \c bool (or convertible) arc map. The algorithm
   572     ///will stop when it reaches an arc \c a with <tt>am[a]</tt> true.
   573     ///
   574     ///\return The reached arc \c a with <tt>am[a]</tt> true or
   575     ///\c INVALID if no such arc was found.
   576     ///
   577     ///\pre init() must be called and a root node should be
   578     ///added with addSource() before using this function.
   579     ///
   580     ///\warning Contrary to \ref Bfs and \ref Dijkstra, \c am is an arc map,
   581     ///not a node map.
   582     template<class ArcBoolMap>
   583     Arc start(const ArcBoolMap &am)
   584     {
   585       while ( !emptyQueue() && !am[_stack[_stack_head]] )
   586         processNextArc();
   587       return emptyQueue() ? INVALID : _stack[_stack_head];
   588     }
   589 
   590     ///Runs the algorithm from the given source node.
   591 
   592     ///This method runs the %DFS algorithm from node \c s
   593     ///in order to compute the DFS path to each node.
   594     ///
   595     ///The algorithm computes
   596     ///- the %DFS tree,
   597     ///- the distance of each node from the root in the %DFS tree.
   598     ///
   599     ///\note <tt>d.run(s)</tt> is just a shortcut of the following code.
   600     ///\code
   601     ///  d.init();
   602     ///  d.addSource(s);
   603     ///  d.start();
   604     ///\endcode
   605     void run(Node s) {
   606       init();
   607       addSource(s);
   608       start();
   609     }
   610 
   611     ///Finds the %DFS path between \c s and \c t.
   612 
   613     ///This method runs the %DFS algorithm from node \c s
   614     ///in order to compute the DFS path to node \c t
   615     ///(it stops searching when \c t is processed)
   616     ///
   617     ///\return \c true if \c t is reachable form \c s.
   618     ///
   619     ///\note Apart from the return value, <tt>d.run(s,t)</tt> is
   620     ///just a shortcut of the following code.
   621     ///\code
   622     ///  d.init();
   623     ///  d.addSource(s);
   624     ///  d.start(t);
   625     ///\endcode
   626     bool run(Node s,Node t) {
   627       init();
   628       addSource(s);
   629       start(t);
   630       return reached(t);
   631     }
   632 
   633     ///Runs the algorithm to visit all nodes in the digraph.
   634 
   635     ///This method runs the %DFS algorithm in order to compute the
   636     ///%DFS path to each node.
   637     ///
   638     ///The algorithm computes
   639     ///- the %DFS tree (forest),
   640     ///- the distance of each node from the root(s) in the %DFS tree.
   641     ///
   642     ///\note <tt>d.run()</tt> is just a shortcut of the following code.
   643     ///\code
   644     ///  d.init();
   645     ///  for (NodeIt n(digraph); n != INVALID; ++n) {
   646     ///    if (!d.reached(n)) {
   647     ///      d.addSource(n);
   648     ///      d.start();
   649     ///    }
   650     ///  }
   651     ///\endcode
   652     void run() {
   653       init();
   654       for (NodeIt it(*G); it != INVALID; ++it) {
   655         if (!reached(it)) {
   656           addSource(it);
   657           start();
   658         }
   659       }
   660     }
   661 
   662     ///@}
   663 
   664     ///\name Query Functions
   665     ///The results of the DFS algorithm can be obtained using these
   666     ///functions.\n
   667     ///Either \ref run(Node) "run()" or \ref start() should be called
   668     ///before using them.
   669 
   670     ///@{
   671 
   672     ///The DFS path to a node.
   673 
   674     ///Returns the DFS path to a node.
   675     ///
   676     ///\warning \c t should be reached from the root(s).
   677     ///
   678     ///\pre Either \ref run(Node) "run()" or \ref init()
   679     ///must be called before using this function.
   680     Path path(Node t) const { return Path(*G, *_pred, t); }
   681 
   682     ///The distance of a node from the root(s).
   683 
   684     ///Returns the distance of a node from the root(s).
   685     ///
   686     ///\warning If node \c v is not reached from the root(s), then
   687     ///the return value of this function is undefined.
   688     ///
   689     ///\pre Either \ref run(Node) "run()" or \ref init()
   690     ///must be called before using this function.
   691     int dist(Node v) const { return (*_dist)[v]; }
   692 
   693     ///Returns the 'previous arc' of the %DFS tree for a node.
   694 
   695     ///This function returns the 'previous arc' of the %DFS tree for the
   696     ///node \c v, i.e. it returns the last arc of a %DFS path from a
   697     ///root to \c v. It is \c INVALID if \c v is not reached from the
   698     ///root(s) or if \c v is a root.
   699     ///
   700     ///The %DFS tree used here is equal to the %DFS tree used in
   701     ///\ref predNode().
   702     ///
   703     ///\pre Either \ref run(Node) "run()" or \ref init()
   704     ///must be called before using this function.
   705     Arc predArc(Node v) const { return (*_pred)[v];}
   706 
   707     ///Returns the 'previous node' of the %DFS tree.
   708 
   709     ///This function returns the 'previous node' of the %DFS
   710     ///tree for the node \c v, i.e. it returns the last but one node
   711     ///from a %DFS path from a root to \c v. It is \c INVALID
   712     ///if \c v is not reached from the root(s) or if \c v is a root.
   713     ///
   714     ///The %DFS tree used here is equal to the %DFS tree used in
   715     ///\ref predArc().
   716     ///
   717     ///\pre Either \ref run(Node) "run()" or \ref init()
   718     ///must be called before using this function.
   719     Node predNode(Node v) const { return (*_pred)[v]==INVALID ? INVALID:
   720                                   G->source((*_pred)[v]); }
   721 
   722     ///\brief Returns a const reference to the node map that stores the
   723     ///distances of the nodes.
   724     ///
   725     ///Returns a const reference to the node map that stores the
   726     ///distances of the nodes calculated by the algorithm.
   727     ///
   728     ///\pre Either \ref run(Node) "run()" or \ref init()
   729     ///must be called before using this function.
   730     const DistMap &distMap() const { return *_dist;}
   731 
   732     ///\brief Returns a const reference to the node map that stores the
   733     ///predecessor arcs.
   734     ///
   735     ///Returns a const reference to the node map that stores the predecessor
   736     ///arcs, which form the DFS tree.
   737     ///
   738     ///\pre Either \ref run(Node) "run()" or \ref init()
   739     ///must be called before using this function.
   740     const PredMap &predMap() const { return *_pred;}
   741 
   742     ///Checks if a node is reached from the root(s).
   743 
   744     ///Returns \c true if \c v is reached from the root(s).
   745     ///
   746     ///\pre Either \ref run(Node) "run()" or \ref init()
   747     ///must be called before using this function.
   748     bool reached(Node v) const { return (*_reached)[v]; }
   749 
   750     ///@}
   751   };
   752 
   753   ///Default traits class of dfs() function.
   754 
   755   ///Default traits class of dfs() function.
   756   ///\tparam GR Digraph type.
   757   template<class GR>
   758   struct DfsWizardDefaultTraits
   759   {
   760     ///The type of the digraph the algorithm runs on.
   761     typedef GR Digraph;
   762 
   763     ///\brief The type of the map that stores the predecessor
   764     ///arcs of the %DFS paths.
   765     ///
   766     ///The type of the map that stores the predecessor
   767     ///arcs of the %DFS paths.
   768     ///It must meet the \ref concepts::WriteMap "WriteMap" concept.
   769     typedef typename Digraph::template NodeMap<typename Digraph::Arc> PredMap;
   770     ///Instantiates a PredMap.
   771 
   772     ///This function instantiates a PredMap.
   773     ///\param g is the digraph, to which we would like to define the
   774     ///PredMap.
   775     static PredMap *createPredMap(const Digraph &g)
   776     {
   777       return new PredMap(g);
   778     }
   779 
   780     ///The type of the map that indicates which nodes are processed.
   781 
   782     ///The type of the map that indicates which nodes are processed.
   783     ///It must meet the \ref concepts::WriteMap "WriteMap" concept.
   784     ///By default it is a NullMap.
   785     typedef NullMap<typename Digraph::Node,bool> ProcessedMap;
   786     ///Instantiates a ProcessedMap.
   787 
   788     ///This function instantiates a ProcessedMap.
   789     ///\param g is the digraph, to which
   790     ///we would like to define the ProcessedMap.
   791 #ifdef DOXYGEN
   792     static ProcessedMap *createProcessedMap(const Digraph &g)
   793 #else
   794     static ProcessedMap *createProcessedMap(const Digraph &)
   795 #endif
   796     {
   797       return new ProcessedMap();
   798     }
   799 
   800     ///The type of the map that indicates which nodes are reached.
   801 
   802     ///The type of the map that indicates which nodes are reached.
   803     ///It must meet the \ref concepts::ReadWriteMap "ReadWriteMap" concept.
   804     typedef typename Digraph::template NodeMap<bool> ReachedMap;
   805     ///Instantiates a ReachedMap.
   806 
   807     ///This function instantiates a ReachedMap.
   808     ///\param g is the digraph, to which
   809     ///we would like to define the ReachedMap.
   810     static ReachedMap *createReachedMap(const Digraph &g)
   811     {
   812       return new ReachedMap(g);
   813     }
   814 
   815     ///The type of the map that stores the distances of the nodes.
   816 
   817     ///The type of the map that stores the distances of the nodes.
   818     ///It must meet the \ref concepts::WriteMap "WriteMap" concept.
   819     typedef typename Digraph::template NodeMap<int> DistMap;
   820     ///Instantiates a DistMap.
   821 
   822     ///This function instantiates a DistMap.
   823     ///\param g is the digraph, to which we would like to define
   824     ///the DistMap
   825     static DistMap *createDistMap(const Digraph &g)
   826     {
   827       return new DistMap(g);
   828     }
   829 
   830     ///The type of the DFS paths.
   831 
   832     ///The type of the DFS paths.
   833     ///It must meet the \ref concepts::Path "Path" concept.
   834     typedef lemon::Path<Digraph> Path;
   835   };
   836 
   837   /// Default traits class used by DfsWizard
   838 
   839   /// To make it easier to use Dfs algorithm
   840   /// we have created a wizard class.
   841   /// This \ref DfsWizard class needs default traits,
   842   /// as well as the \ref Dfs class.
   843   /// The \ref DfsWizardBase is a class to be the default traits of the
   844   /// \ref DfsWizard class.
   845   template<class GR>
   846   class DfsWizardBase : public DfsWizardDefaultTraits<GR>
   847   {
   848 
   849     typedef DfsWizardDefaultTraits<GR> Base;
   850   protected:
   851     //The type of the nodes in the digraph.
   852     typedef typename Base::Digraph::Node Node;
   853 
   854     //Pointer to the digraph the algorithm runs on.
   855     void *_g;
   856     //Pointer to the map of reached nodes.
   857     void *_reached;
   858     //Pointer to the map of processed nodes.
   859     void *_processed;
   860     //Pointer to the map of predecessors arcs.
   861     void *_pred;
   862     //Pointer to the map of distances.
   863     void *_dist;
   864     //Pointer to the DFS path to the target node.
   865     void *_path;
   866     //Pointer to the distance of the target node.
   867     int *_di;
   868 
   869     public:
   870     /// Constructor.
   871 
   872     /// This constructor does not require parameters, therefore it initiates
   873     /// all of the attributes to \c 0.
   874     DfsWizardBase() : _g(0), _reached(0), _processed(0), _pred(0),
   875                       _dist(0), _path(0), _di(0) {}
   876 
   877     /// Constructor.
   878 
   879     /// This constructor requires one parameter,
   880     /// others are initiated to \c 0.
   881     /// \param g The digraph the algorithm runs on.
   882     DfsWizardBase(const GR &g) :
   883       _g(reinterpret_cast<void*>(const_cast<GR*>(&g))),
   884       _reached(0), _processed(0), _pred(0), _dist(0),  _path(0), _di(0) {}
   885 
   886   };
   887 
   888   /// Auxiliary class for the function-type interface of DFS algorithm.
   889 
   890   /// This auxiliary class is created to implement the
   891   /// \ref dfs() "function-type interface" of \ref Dfs algorithm.
   892   /// It does not have own \ref run(Node) "run()" method, it uses the
   893   /// functions and features of the plain \ref Dfs.
   894   ///
   895   /// This class should only be used through the \ref dfs() function,
   896   /// which makes it easier to use the algorithm.
   897   template<class TR>
   898   class DfsWizard : public TR
   899   {
   900     typedef TR Base;
   901 
   902     ///The type of the digraph the algorithm runs on.
   903     typedef typename TR::Digraph Digraph;
   904 
   905     typedef typename Digraph::Node Node;
   906     typedef typename Digraph::NodeIt NodeIt;
   907     typedef typename Digraph::Arc Arc;
   908     typedef typename Digraph::OutArcIt OutArcIt;
   909 
   910     ///\brief The type of the map that stores the predecessor
   911     ///arcs of the DFS paths.
   912     typedef typename TR::PredMap PredMap;
   913     ///\brief The type of the map that stores the distances of the nodes.
   914     typedef typename TR::DistMap DistMap;
   915     ///\brief The type of the map that indicates which nodes are reached.
   916     typedef typename TR::ReachedMap ReachedMap;
   917     ///\brief The type of the map that indicates which nodes are processed.
   918     typedef typename TR::ProcessedMap ProcessedMap;
   919     ///The type of the DFS paths
   920     typedef typename TR::Path Path;
   921 
   922   public:
   923 
   924     /// Constructor.
   925     DfsWizard() : TR() {}
   926 
   927     /// Constructor that requires parameters.
   928 
   929     /// Constructor that requires parameters.
   930     /// These parameters will be the default values for the traits class.
   931     /// \param g The digraph the algorithm runs on.
   932     DfsWizard(const Digraph &g) :
   933       TR(g) {}
   934 
   935     ///Copy constructor
   936     DfsWizard(const TR &b) : TR(b) {}
   937 
   938     ~DfsWizard() {}
   939 
   940     ///Runs DFS algorithm from the given source node.
   941 
   942     ///This method runs DFS algorithm from node \c s
   943     ///in order to compute the DFS path to each node.
   944     void run(Node s)
   945     {
   946       Dfs<Digraph,TR> alg(*reinterpret_cast<const Digraph*>(Base::_g));
   947       if (Base::_pred)
   948         alg.predMap(*reinterpret_cast<PredMap*>(Base::_pred));
   949       if (Base::_dist)
   950         alg.distMap(*reinterpret_cast<DistMap*>(Base::_dist));
   951       if (Base::_reached)
   952         alg.reachedMap(*reinterpret_cast<ReachedMap*>(Base::_reached));
   953       if (Base::_processed)
   954         alg.processedMap(*reinterpret_cast<ProcessedMap*>(Base::_processed));
   955       if (s!=INVALID)
   956         alg.run(s);
   957       else
   958         alg.run();
   959     }
   960 
   961     ///Finds the DFS path between \c s and \c t.
   962 
   963     ///This method runs DFS algorithm from node \c s
   964     ///in order to compute the DFS path to node \c t
   965     ///(it stops searching when \c t is processed).
   966     ///
   967     ///\return \c true if \c t is reachable form \c s.
   968     bool run(Node s, Node t)
   969     {
   970       Dfs<Digraph,TR> alg(*reinterpret_cast<const Digraph*>(Base::_g));
   971       if (Base::_pred)
   972         alg.predMap(*reinterpret_cast<PredMap*>(Base::_pred));
   973       if (Base::_dist)
   974         alg.distMap(*reinterpret_cast<DistMap*>(Base::_dist));
   975       if (Base::_reached)
   976         alg.reachedMap(*reinterpret_cast<ReachedMap*>(Base::_reached));
   977       if (Base::_processed)
   978         alg.processedMap(*reinterpret_cast<ProcessedMap*>(Base::_processed));
   979       alg.run(s,t);
   980       if (Base::_path)
   981         *reinterpret_cast<Path*>(Base::_path) = alg.path(t);
   982       if (Base::_di)
   983         *Base::_di = alg.dist(t);
   984       return alg.reached(t);
   985       }
   986 
   987     ///Runs DFS algorithm to visit all nodes in the digraph.
   988 
   989     ///This method runs DFS algorithm in order to compute
   990     ///the DFS path to each node.
   991     void run()
   992     {
   993       run(INVALID);
   994     }
   995 
   996     template<class T>
   997     struct SetPredMapBase : public Base {
   998       typedef T PredMap;
   999       static PredMap *createPredMap(const Digraph &) { return 0; };
  1000       SetPredMapBase(const TR &b) : TR(b) {}
  1001     };
  1002     ///\brief \ref named-func-param "Named parameter"
  1003     ///for setting PredMap object.
  1004     ///
  1005     ///\ref named-func-param "Named parameter"
  1006     ///for setting PredMap object.
  1007     template<class T>
  1008     DfsWizard<SetPredMapBase<T> > predMap(const T &t)
  1009     {
  1010       Base::_pred=reinterpret_cast<void*>(const_cast<T*>(&t));
  1011       return DfsWizard<SetPredMapBase<T> >(*this);
  1012     }
  1013 
  1014     template<class T>
  1015     struct SetReachedMapBase : public Base {
  1016       typedef T ReachedMap;
  1017       static ReachedMap *createReachedMap(const Digraph &) { return 0; };
  1018       SetReachedMapBase(const TR &b) : TR(b) {}
  1019     };
  1020     ///\brief \ref named-func-param "Named parameter"
  1021     ///for setting ReachedMap object.
  1022     ///
  1023     /// \ref named-func-param "Named parameter"
  1024     ///for setting ReachedMap object.
  1025     template<class T>
  1026     DfsWizard<SetReachedMapBase<T> > reachedMap(const T &t)
  1027     {
  1028       Base::_reached=reinterpret_cast<void*>(const_cast<T*>(&t));
  1029       return DfsWizard<SetReachedMapBase<T> >(*this);
  1030     }
  1031 
  1032     template<class T>
  1033     struct SetDistMapBase : public Base {
  1034       typedef T DistMap;
  1035       static DistMap *createDistMap(const Digraph &) { return 0; };
  1036       SetDistMapBase(const TR &b) : TR(b) {}
  1037     };
  1038     ///\brief \ref named-func-param "Named parameter"
  1039     ///for setting DistMap object.
  1040     ///
  1041     /// \ref named-func-param "Named parameter"
  1042     ///for setting DistMap object.
  1043     template<class T>
  1044     DfsWizard<SetDistMapBase<T> > distMap(const T &t)
  1045     {
  1046       Base::_dist=reinterpret_cast<void*>(const_cast<T*>(&t));
  1047       return DfsWizard<SetDistMapBase<T> >(*this);
  1048     }
  1049 
  1050     template<class T>
  1051     struct SetProcessedMapBase : public Base {
  1052       typedef T ProcessedMap;
  1053       static ProcessedMap *createProcessedMap(const Digraph &) { return 0; };
  1054       SetProcessedMapBase(const TR &b) : TR(b) {}
  1055     };
  1056     ///\brief \ref named-func-param "Named parameter"
  1057     ///for setting ProcessedMap object.
  1058     ///
  1059     /// \ref named-func-param "Named parameter"
  1060     ///for setting ProcessedMap object.
  1061     template<class T>
  1062     DfsWizard<SetProcessedMapBase<T> > processedMap(const T &t)
  1063     {
  1064       Base::_processed=reinterpret_cast<void*>(const_cast<T*>(&t));
  1065       return DfsWizard<SetProcessedMapBase<T> >(*this);
  1066     }
  1067 
  1068     template<class T>
  1069     struct SetPathBase : public Base {
  1070       typedef T Path;
  1071       SetPathBase(const TR &b) : TR(b) {}
  1072     };
  1073     ///\brief \ref named-func-param "Named parameter"
  1074     ///for getting the DFS path to the target node.
  1075     ///
  1076     ///\ref named-func-param "Named parameter"
  1077     ///for getting the DFS path to the target node.
  1078     template<class T>
  1079     DfsWizard<SetPathBase<T> > path(const T &t)
  1080     {
  1081       Base::_path=reinterpret_cast<void*>(const_cast<T*>(&t));
  1082       return DfsWizard<SetPathBase<T> >(*this);
  1083     }
  1084 
  1085     ///\brief \ref named-func-param "Named parameter"
  1086     ///for getting the distance of the target node.
  1087     ///
  1088     ///\ref named-func-param "Named parameter"
  1089     ///for getting the distance of the target node.
  1090     DfsWizard dist(const int &d)
  1091     {
  1092       Base::_di=const_cast<int*>(&d);
  1093       return *this;
  1094     }
  1095 
  1096   };
  1097 
  1098   ///Function-type interface for DFS algorithm.
  1099 
  1100   ///\ingroup search
  1101   ///Function-type interface for DFS algorithm.
  1102   ///
  1103   ///This function also has several \ref named-func-param "named parameters",
  1104   ///they are declared as the members of class \ref DfsWizard.
  1105   ///The following examples show how to use these parameters.
  1106   ///\code
  1107   ///  // Compute the DFS tree
  1108   ///  dfs(g).predMap(preds).distMap(dists).run(s);
  1109   ///
  1110   ///  // Compute the DFS path from s to t
  1111   ///  bool reached = dfs(g).path(p).dist(d).run(s,t);
  1112   ///\endcode
  1113   ///\warning Don't forget to put the \ref DfsWizard::run(Node) "run()"
  1114   ///to the end of the parameter list.
  1115   ///\sa DfsWizard
  1116   ///\sa Dfs
  1117   template<class GR>
  1118   DfsWizard<DfsWizardBase<GR> >
  1119   dfs(const GR &digraph)
  1120   {
  1121     return DfsWizard<DfsWizardBase<GR> >(digraph);
  1122   }
  1123 
  1124 #ifdef DOXYGEN
  1125   /// \brief Visitor class for DFS.
  1126   ///
  1127   /// This class defines the interface of the DfsVisit events, and
  1128   /// it could be the base of a real visitor class.
  1129   template <typename GR>
  1130   struct DfsVisitor {
  1131     typedef GR Digraph;
  1132     typedef typename Digraph::Arc Arc;
  1133     typedef typename Digraph::Node Node;
  1134     /// \brief Called for the source node of the DFS.
  1135     ///
  1136     /// This function is called for the source node of the DFS.
  1137     void start(const Node& node) {}
  1138     /// \brief Called when the source node is leaved.
  1139     ///
  1140     /// This function is called when the source node is leaved.
  1141     void stop(const Node& node) {}
  1142     /// \brief Called when a node is reached first time.
  1143     ///
  1144     /// This function is called when a node is reached first time.
  1145     void reach(const Node& node) {}
  1146     /// \brief Called when an arc reaches a new node.
  1147     ///
  1148     /// This function is called when the DFS finds an arc whose target node
  1149     /// is not reached yet.
  1150     void discover(const Arc& arc) {}
  1151     /// \brief Called when an arc is examined but its target node is
  1152     /// already discovered.
  1153     ///
  1154     /// This function is called when an arc is examined but its target node is
  1155     /// already discovered.
  1156     void examine(const Arc& arc) {}
  1157     /// \brief Called when the DFS steps back from a node.
  1158     ///
  1159     /// This function is called when the DFS steps back from a node.
  1160     void leave(const Node& node) {}
  1161     /// \brief Called when the DFS steps back on an arc.
  1162     ///
  1163     /// This function is called when the DFS steps back on an arc.
  1164     void backtrack(const Arc& arc) {}
  1165   };
  1166 #else
  1167   template <typename GR>
  1168   struct DfsVisitor {
  1169     typedef GR Digraph;
  1170     typedef typename Digraph::Arc Arc;
  1171     typedef typename Digraph::Node Node;
  1172     void start(const Node&) {}
  1173     void stop(const Node&) {}
  1174     void reach(const Node&) {}
  1175     void discover(const Arc&) {}
  1176     void examine(const Arc&) {}
  1177     void leave(const Node&) {}
  1178     void backtrack(const Arc&) {}
  1179 
  1180     template <typename _Visitor>
  1181     struct Constraints {
  1182       void constraints() {
  1183         Arc arc;
  1184         Node node;
  1185         visitor.start(node);
  1186         visitor.stop(arc);
  1187         visitor.reach(node);
  1188         visitor.discover(arc);
  1189         visitor.examine(arc);
  1190         visitor.leave(node);
  1191         visitor.backtrack(arc);
  1192       }
  1193       _Visitor& visitor;
  1194       Constraints() {}
  1195     };
  1196   };
  1197 #endif
  1198 
  1199   /// \brief Default traits class of DfsVisit class.
  1200   ///
  1201   /// Default traits class of DfsVisit class.
  1202   /// \tparam _Digraph The type of the digraph the algorithm runs on.
  1203   template<class GR>
  1204   struct DfsVisitDefaultTraits {
  1205 
  1206     /// \brief The type of the digraph the algorithm runs on.
  1207     typedef GR Digraph;
  1208 
  1209     /// \brief The type of the map that indicates which nodes are reached.
  1210     ///
  1211     /// The type of the map that indicates which nodes are reached.
  1212     /// It must meet the \ref concepts::ReadWriteMap "ReadWriteMap" concept.
  1213     typedef typename Digraph::template NodeMap<bool> ReachedMap;
  1214 
  1215     /// \brief Instantiates a ReachedMap.
  1216     ///
  1217     /// This function instantiates a ReachedMap.
  1218     /// \param digraph is the digraph, to which
  1219     /// we would like to define the ReachedMap.
  1220     static ReachedMap *createReachedMap(const Digraph &digraph) {
  1221       return new ReachedMap(digraph);
  1222     }
  1223 
  1224   };
  1225 
  1226   /// \ingroup search
  1227   ///
  1228   /// \brief DFS algorithm class with visitor interface.
  1229   ///
  1230   /// This class provides an efficient implementation of the DFS algorithm
  1231   /// with visitor interface.
  1232   ///
  1233   /// The DfsVisit class provides an alternative interface to the Dfs
  1234   /// class. It works with callback mechanism, the DfsVisit object calls
  1235   /// the member functions of the \c Visitor class on every DFS event.
  1236   ///
  1237   /// This interface of the DFS algorithm should be used in special cases
  1238   /// when extra actions have to be performed in connection with certain
  1239   /// events of the DFS algorithm. Otherwise consider to use Dfs or dfs()
  1240   /// instead.
  1241   ///
  1242   /// \tparam GR The type of the digraph the algorithm runs on.
  1243   /// The default type is \ref ListDigraph.
  1244   /// The value of GR is not used directly by \ref DfsVisit,
  1245   /// it is only passed to \ref DfsVisitDefaultTraits.
  1246   /// \tparam VS The Visitor type that is used by the algorithm.
  1247   /// \ref DfsVisitor "DfsVisitor<GR>" is an empty visitor, which
  1248   /// does not observe the DFS events. If you want to observe the DFS
  1249   /// events, you should implement your own visitor class.
  1250   /// \tparam TR Traits class to set various data types used by the
  1251   /// algorithm. The default traits class is
  1252   /// \ref DfsVisitDefaultTraits "DfsVisitDefaultTraits<GR>".
  1253   /// See \ref DfsVisitDefaultTraits for the documentation of
  1254   /// a DFS visit traits class.
  1255 #ifdef DOXYGEN
  1256   template <typename GR, typename VS, typename TR>
  1257 #else
  1258   template <typename GR = ListDigraph,
  1259             typename VS = DfsVisitor<GR>,
  1260             typename TR = DfsVisitDefaultTraits<GR> >
  1261 #endif
  1262   class DfsVisit {
  1263   public:
  1264 
  1265     ///The traits class.
  1266     typedef TR Traits;
  1267 
  1268     ///The type of the digraph the algorithm runs on.
  1269     typedef typename Traits::Digraph Digraph;
  1270 
  1271     ///The visitor type used by the algorithm.
  1272     typedef VS Visitor;
  1273 
  1274     ///The type of the map that indicates which nodes are reached.
  1275     typedef typename Traits::ReachedMap ReachedMap;
  1276 
  1277   private:
  1278 
  1279     typedef typename Digraph::Node Node;
  1280     typedef typename Digraph::NodeIt NodeIt;
  1281     typedef typename Digraph::Arc Arc;
  1282     typedef typename Digraph::OutArcIt OutArcIt;
  1283 
  1284     //Pointer to the underlying digraph.
  1285     const Digraph *_digraph;
  1286     //Pointer to the visitor object.
  1287     Visitor *_visitor;
  1288     //Pointer to the map of reached status of the nodes.
  1289     ReachedMap *_reached;
  1290     //Indicates if _reached is locally allocated (true) or not.
  1291     bool local_reached;
  1292 
  1293     std::vector<typename Digraph::Arc> _stack;
  1294     int _stack_head;
  1295 
  1296     //Creates the maps if necessary.
  1297     void create_maps() {
  1298       if(!_reached) {
  1299         local_reached = true;
  1300         _reached = Traits::createReachedMap(*_digraph);
  1301       }
  1302     }
  1303 
  1304   protected:
  1305 
  1306     DfsVisit() {}
  1307 
  1308   public:
  1309 
  1310     typedef DfsVisit Create;
  1311 
  1312     /// \name Named Template Parameters
  1313 
  1314     ///@{
  1315     template <class T>
  1316     struct SetReachedMapTraits : public Traits {
  1317       typedef T ReachedMap;
  1318       static ReachedMap *createReachedMap(const Digraph &digraph) {
  1319         LEMON_ASSERT(false, "ReachedMap is not initialized");
  1320         return 0; // ignore warnings
  1321       }
  1322     };
  1323     /// \brief \ref named-templ-param "Named parameter" for setting
  1324     /// ReachedMap type.
  1325     ///
  1326     /// \ref named-templ-param "Named parameter" for setting ReachedMap type.
  1327     template <class T>
  1328     struct SetReachedMap : public DfsVisit< Digraph, Visitor,
  1329                                             SetReachedMapTraits<T> > {
  1330       typedef DfsVisit< Digraph, Visitor, SetReachedMapTraits<T> > Create;
  1331     };
  1332     ///@}
  1333 
  1334   public:
  1335 
  1336     /// \brief Constructor.
  1337     ///
  1338     /// Constructor.
  1339     ///
  1340     /// \param digraph The digraph the algorithm runs on.
  1341     /// \param visitor The visitor object of the algorithm.
  1342     DfsVisit(const Digraph& digraph, Visitor& visitor)
  1343       : _digraph(&digraph), _visitor(&visitor),
  1344         _reached(0), local_reached(false) {}
  1345 
  1346     /// \brief Destructor.
  1347     ~DfsVisit() {
  1348       if(local_reached) delete _reached;
  1349     }
  1350 
  1351     /// \brief Sets the map that indicates which nodes are reached.
  1352     ///
  1353     /// Sets the map that indicates which nodes are reached.
  1354     /// If you don't use this function before calling \ref run(Node) "run()"
  1355     /// or \ref init(), an instance will be allocated automatically.
  1356     /// The destructor deallocates this automatically allocated map,
  1357     /// of course.
  1358     /// \return <tt> (*this) </tt>
  1359     DfsVisit &reachedMap(ReachedMap &m) {
  1360       if(local_reached) {
  1361         delete _reached;
  1362         local_reached=false;
  1363       }
  1364       _reached = &m;
  1365       return *this;
  1366     }
  1367 
  1368   public:
  1369 
  1370     /// \name Execution Control
  1371     /// The simplest way to execute the DFS algorithm is to use one of the
  1372     /// member functions called \ref run(Node) "run()".\n
  1373     /// If you need more control on the execution, first you have to call
  1374     /// \ref init(), then you can add a source node with \ref addSource()
  1375     /// and perform the actual computation with \ref start().
  1376     /// This procedure can be repeated if there are nodes that have not
  1377     /// been reached.
  1378 
  1379     /// @{
  1380 
  1381     /// \brief Initializes the internal data structures.
  1382     ///
  1383     /// Initializes the internal data structures.
  1384     void init() {
  1385       create_maps();
  1386       _stack.resize(countNodes(*_digraph));
  1387       _stack_head = -1;
  1388       for (NodeIt u(*_digraph) ; u != INVALID ; ++u) {
  1389         _reached->set(u, false);
  1390       }
  1391     }
  1392 
  1393     /// \brief Adds a new source node.
  1394     ///
  1395     /// Adds a new source node to the set of nodes to be processed.
  1396     ///
  1397     /// \pre The stack must be empty. Otherwise the algorithm gives
  1398     /// wrong results. (One of the outgoing arcs of all the source nodes
  1399     /// except for the last one will not be visited and distances will
  1400     /// also be wrong.)
  1401     void addSource(Node s)
  1402     {
  1403       LEMON_DEBUG(emptyQueue(), "The stack is not empty.");
  1404       if(!(*_reached)[s]) {
  1405           _reached->set(s,true);
  1406           _visitor->start(s);
  1407           _visitor->reach(s);
  1408           Arc e;
  1409           _digraph->firstOut(e, s);
  1410           if (e != INVALID) {
  1411             _stack[++_stack_head] = e;
  1412           } else {
  1413             _visitor->leave(s);
  1414             _visitor->stop(s);
  1415           }
  1416         }
  1417     }
  1418 
  1419     /// \brief Processes the next arc.
  1420     ///
  1421     /// Processes the next arc.
  1422     ///
  1423     /// \return The processed arc.
  1424     ///
  1425     /// \pre The stack must not be empty.
  1426     Arc processNextArc() {
  1427       Arc e = _stack[_stack_head];
  1428       Node m = _digraph->target(e);
  1429       if(!(*_reached)[m]) {
  1430         _visitor->discover(e);
  1431         _visitor->reach(m);
  1432         _reached->set(m, true);
  1433         _digraph->firstOut(_stack[++_stack_head], m);
  1434       } else {
  1435         _visitor->examine(e);
  1436         m = _digraph->source(e);
  1437         _digraph->nextOut(_stack[_stack_head]);
  1438       }
  1439       while (_stack_head>=0 && _stack[_stack_head] == INVALID) {
  1440         _visitor->leave(m);
  1441         --_stack_head;
  1442         if (_stack_head >= 0) {
  1443           _visitor->backtrack(_stack[_stack_head]);
  1444           m = _digraph->source(_stack[_stack_head]);
  1445           _digraph->nextOut(_stack[_stack_head]);
  1446         } else {
  1447           _visitor->stop(m);
  1448         }
  1449       }
  1450       return e;
  1451     }
  1452 
  1453     /// \brief Next arc to be processed.
  1454     ///
  1455     /// Next arc to be processed.
  1456     ///
  1457     /// \return The next arc to be processed or INVALID if the stack is
  1458     /// empty.
  1459     Arc nextArc() const {
  1460       return _stack_head >= 0 ? _stack[_stack_head] : INVALID;
  1461     }
  1462 
  1463     /// \brief Returns \c false if there are nodes
  1464     /// to be processed.
  1465     ///
  1466     /// Returns \c false if there are nodes
  1467     /// to be processed in the queue (stack).
  1468     bool emptyQueue() const { return _stack_head < 0; }
  1469 
  1470     /// \brief Returns the number of the nodes to be processed.
  1471     ///
  1472     /// Returns the number of the nodes to be processed in the queue (stack).
  1473     int queueSize() const { return _stack_head + 1; }
  1474 
  1475     /// \brief Executes the algorithm.
  1476     ///
  1477     /// Executes the algorithm.
  1478     ///
  1479     /// This method runs the %DFS algorithm from the root node
  1480     /// in order to compute the %DFS path to each node.
  1481     ///
  1482     /// The algorithm computes
  1483     /// - the %DFS tree,
  1484     /// - the distance of each node from the root in the %DFS tree.
  1485     ///
  1486     /// \pre init() must be called and a root node should be
  1487     /// added with addSource() before using this function.
  1488     ///
  1489     /// \note <tt>d.start()</tt> is just a shortcut of the following code.
  1490     /// \code
  1491     ///   while ( !d.emptyQueue() ) {
  1492     ///     d.processNextArc();
  1493     ///   }
  1494     /// \endcode
  1495     void start() {
  1496       while ( !emptyQueue() ) processNextArc();
  1497     }
  1498 
  1499     /// \brief Executes the algorithm until the given target node is reached.
  1500     ///
  1501     /// Executes the algorithm until the given target node is reached.
  1502     ///
  1503     /// This method runs the %DFS algorithm from the root node
  1504     /// in order to compute the DFS path to \c t.
  1505     ///
  1506     /// The algorithm computes
  1507     /// - the %DFS path to \c t,
  1508     /// - the distance of \c t from the root in the %DFS tree.
  1509     ///
  1510     /// \pre init() must be called and a root node should be added
  1511     /// with addSource() before using this function.
  1512     void start(Node t) {
  1513       while ( !emptyQueue() && !(*_reached)[t] )
  1514         processNextArc();
  1515     }
  1516 
  1517     /// \brief Executes the algorithm until a condition is met.
  1518     ///
  1519     /// Executes the algorithm until a condition is met.
  1520     ///
  1521     /// This method runs the %DFS algorithm from the root node
  1522     /// until an arc \c a with <tt>am[a]</tt> true is found.
  1523     ///
  1524     /// \param am A \c bool (or convertible) arc map. The algorithm
  1525     /// will stop when it reaches an arc \c a with <tt>am[a]</tt> true.
  1526     ///
  1527     /// \return The reached arc \c a with <tt>am[a]</tt> true or
  1528     /// \c INVALID if no such arc was found.
  1529     ///
  1530     /// \pre init() must be called and a root node should be added
  1531     /// with addSource() before using this function.
  1532     ///
  1533     /// \warning Contrary to \ref Bfs and \ref Dijkstra, \c am is an arc map,
  1534     /// not a node map.
  1535     template <typename AM>
  1536     Arc start(const AM &am) {
  1537       while ( !emptyQueue() && !am[_stack[_stack_head]] )
  1538         processNextArc();
  1539       return emptyQueue() ? INVALID : _stack[_stack_head];
  1540     }
  1541 
  1542     /// \brief Runs the algorithm from the given source node.
  1543     ///
  1544     /// This method runs the %DFS algorithm from node \c s.
  1545     /// in order to compute the DFS path to each node.
  1546     ///
  1547     /// The algorithm computes
  1548     /// - the %DFS tree,
  1549     /// - the distance of each node from the root in the %DFS tree.
  1550     ///
  1551     /// \note <tt>d.run(s)</tt> is just a shortcut of the following code.
  1552     ///\code
  1553     ///   d.init();
  1554     ///   d.addSource(s);
  1555     ///   d.start();
  1556     ///\endcode
  1557     void run(Node s) {
  1558       init();
  1559       addSource(s);
  1560       start();
  1561     }
  1562 
  1563     /// \brief Finds the %DFS path between \c s and \c t.
  1564 
  1565     /// This method runs the %DFS algorithm from node \c s
  1566     /// in order to compute the DFS path to node \c t
  1567     /// (it stops searching when \c t is processed).
  1568     ///
  1569     /// \return \c true if \c t is reachable form \c s.
  1570     ///
  1571     /// \note Apart from the return value, <tt>d.run(s,t)</tt> is
  1572     /// just a shortcut of the following code.
  1573     ///\code
  1574     ///   d.init();
  1575     ///   d.addSource(s);
  1576     ///   d.start(t);
  1577     ///\endcode
  1578     bool run(Node s,Node t) {
  1579       init();
  1580       addSource(s);
  1581       start(t);
  1582       return reached(t);
  1583     }
  1584 
  1585     /// \brief Runs the algorithm to visit all nodes in the digraph.
  1586 
  1587     /// This method runs the %DFS algorithm in order to
  1588     /// compute the %DFS path to each node.
  1589     ///
  1590     /// The algorithm computes
  1591     /// - the %DFS tree (forest),
  1592     /// - the distance of each node from the root(s) in the %DFS tree.
  1593     ///
  1594     /// \note <tt>d.run()</tt> is just a shortcut of the following code.
  1595     ///\code
  1596     ///   d.init();
  1597     ///   for (NodeIt n(digraph); n != INVALID; ++n) {
  1598     ///     if (!d.reached(n)) {
  1599     ///       d.addSource(n);
  1600     ///       d.start();
  1601     ///     }
  1602     ///   }
  1603     ///\endcode
  1604     void run() {
  1605       init();
  1606       for (NodeIt it(*_digraph); it != INVALID; ++it) {
  1607         if (!reached(it)) {
  1608           addSource(it);
  1609           start();
  1610         }
  1611       }
  1612     }
  1613 
  1614     ///@}
  1615 
  1616     /// \name Query Functions
  1617     /// The results of the DFS algorithm can be obtained using these
  1618     /// functions.\n
  1619     /// Either \ref run(Node) "run()" or \ref start() should be called
  1620     /// before using them.
  1621 
  1622     ///@{
  1623 
  1624     /// \brief Checks if a node is reached from the root(s).
  1625     ///
  1626     /// Returns \c true if \c v is reached from the root(s).
  1627     ///
  1628     /// \pre Either \ref run(Node) "run()" or \ref init()
  1629     /// must be called before using this function.
  1630     bool reached(Node v) const { return (*_reached)[v]; }
  1631 
  1632     ///@}
  1633 
  1634   };
  1635 
  1636 } //END OF NAMESPACE LEMON
  1637 
  1638 #endif