7 #include <for_each_macros.h>
11 /// Kruskal's algorithm to compute a minimum cost tree
13 template <typename Graph, typename InputEdgeOrder, typename OutBoolMap>
14 typename InputEdgeOrder::ValueType
15 Kruskal(Graph const& G, InputEdgeOrder const& edges,
18 typedef typename InputEdgeOrder::ValueType EdgeCost;
19 typedef typename Graph::NodeMap<int> NodeIntMap;
20 typedef typename Graph::Node Node;
22 NodeIntMap comp_map(G, -1);
23 UnionFind<Node,NodeIntMap> uf(comp_map);
25 EdgeCost tot_cost = 0;
26 for (typename InputEdgeOrder::const_iterator p = edges.begin();
27 p!=edges.end(); ++p ) {
28 if ( uf.joinComponents(G.head(edges.first(p)),
29 G.tail(edges.first(p))) ) {
30 out_map.set(edges.first(p), true);
31 tot_cost += edges.second(p);
34 out_map.set(edges.first(p), false);
42 /* ** ** Output-objektumok: egyszeruen extra bool mapek ** ** */
44 /// A writable bool-map that makes a sequence of "true" keys
46 /// A writable bool-map that creates a sequence out of keys that receive
48 /// \warning Not a regular property map, as it doesn't know its KeyType
50 template<typename Iterator>
51 class SequenceOutput {
55 typedef bool ValueType;
57 SequenceOutput(Iterator const &_it) : it(_it) {}
59 template<typename KeyType>
60 void set(KeyType const& k, bool v) { if(v) {*it=k; ++it;} }
63 template<typename Iterator>
65 SequenceOutput<Iterator>
66 makeSequenceOutput(Iterator it) {
67 return SequenceOutput<Iterator>(it);
70 /* ** ** InputSource -ok ** ** */
72 template<typename Key, typename Val>
73 class KruskalPairVec : public std::vector< std::pair<Key,Val> > {
76 typedef std::vector< std::pair<Key,Val> > Parent;
78 typedef Val ValueType;
79 typedef std::pair<Key,Val> PairType;
81 typedef typename Parent::iterator iterator;
82 typedef typename Parent::const_iterator const_iterator;
87 bool operator()(PairType const& a, PairType const& b) {
88 return a.second < b.second;
95 // KruskalPairVec(Parent const& p) : Parent(p) {}
98 std::sort(begin(), end(), comparePair());
101 // FIXME: nem nagyon illik ez ide...
102 template<typename Graph, typename Map>
103 KruskalPairVec(Graph const& G, Map const& m) {
104 typedef typename Graph::EdgeIt EdgeIt;
107 FOR_EACH_LOC(EdgeIt, e, G) {
108 // for (EdgeIt e=G.template first<EdgeIt>(); G.valid(e); G.next(e)) {
109 push_back(make_pair(e, m[e]));
114 Key const& first(const_iterator i) const { return i->first; }
115 Key& first(iterator i) { return i->first; }
117 Val const& second(const_iterator i) const { return i->second; }
118 Val& second(iterator i) { return i->second; }
122 template <typename Map>
123 class KruskalMapVec : public std::vector<typename Map::KeyType> {
126 typedef typename Map::KeyType KeyType;
127 typedef typename Map::ValueType ValueType;
129 typedef typename std::vector<KeyType> Parent;
130 typedef typename Parent::iterator iterator;
131 typedef typename Parent::const_iterator const_iterator;
140 compareKeys(Map const &_m) : m(_m) {}
141 bool operator()(KeyType const& a, KeyType const& b) {
148 KruskalMapVec(Map const& _m) : m(_m) {}
151 std::sort(begin(), end(), compareKeys(m));
154 // FIXME: nem nagyon illik ez ide...
155 template<typename Graph>
156 KruskalMapVec(Graph const& G, Map const& _m) : m(_m) {
157 typedef typename Graph::EdgeIt EdgeIt;
160 FOR_EACH_LOC(EdgeIt, e, G) {
161 // for (EdgeIt e=G.template first<EdgeIt>(); G.valid(e); G.next(e)) {
167 KeyType const& first(const_iterator i) const { return *i; }
168 KeyType& first(iterator i) { return *i; }
170 ValueType const& second(const_iterator i) const { return m[*i]; }
171 ValueType& second(iterator i) { return m[*i]; }
174 /* ** ** Wrapper fuggvenyek ** ** */
177 /// \brief Wrapper to Kruskal().
178 /// Input is from an EdgeMap, output is a plain boolmap.
179 template <typename Graph, typename EdgeCostMap, typename RetEdgeBoolMap>
180 typename EdgeCostMap::ValueType
181 Kruskal_EdgeCostMapIn_BoolMapOut(Graph const& G,
182 EdgeCostMap const& edge_costs,
183 RetEdgeBoolMap &ret_bool_map) {
185 typedef KruskalPairVec<typename Graph::Edge, typename EdgeCostMap::ValueType>
187 InputVec iv(G, edge_costs);
189 return Kruskal(G, iv, ret_bool_map);
193 /// \brief Wrapper to Kruskal().
194 /// Input is from an EdgeMap, output is to a sequence.
195 template <typename Graph, typename EdgeCostMap, typename RetIterator>
196 typename EdgeCostMap::ValueType
197 Kruskal_EdgeCostMapIn_IteratorOut(Graph const& G,
198 EdgeCostMap const& edge_costs,
199 RetIterator ret_iterator) {
200 typedef SequenceOutput<RetIterator> OutMap;
201 OutMap out(ret_iterator);
203 typedef KruskalPairVec<typename Graph::Edge, typename EdgeCostMap::ValueType>
205 InputVec iv(G, edge_costs);
207 return Kruskal(G, iv, out);
213 #endif //HUGO_KRUSKAL_H