src/work/deba/vector_edge_map.h
author beckerjc
Sat, 17 Apr 2004 21:50:48 +0000
changeset 352 4b89077ab715
permissions -rw-r--r--
A successful work-around for using const map reference as an output
parameter to Kruskal().
     1 #ifndef VECTOR_EDGE_MAP_H
     2 #define VECTOR_EDGE_MAP_H
     3 
     4 #include <vector>
     5 
     6 #include "edge_map_base.h"
     7 
     8 template <typename G, typename E, typename V> 
     9 class VectorEdgeMap : public EdgeMapBase<G, E>{
    10 public:
    11 	typedef V ValueType;
    12 	
    13 	VectorEdgeMap(Graph& g) : EdgeMapBase<G, E>(g) {}
    14 	
    15 	void add(const E& edge) {
    16 		if (edge->id >= container.size()) {
    17 			container.resize(edge->id);
    18 		}
    19 	}
    20 	
    21 	void erase(const E&) {}
    22 
    23 private:
    24 	typedef vector<ValueType> Container;
    25 	
    26 	Container container;
    27 }
    28 
    29 #endif