fix on numberOfEdges

for/release
Denes Matetelki 12 years ago
parent a7fad9cfb0
commit e069792410

@ -68,19 +68,6 @@ private:
std::vector<Vertex> m_vertices; std::vector<Vertex> m_vertices;
}; };
// non-member functions
// template <typename T> typename std::vector<T> subtee_breathFirst(const Graph<T>& graph, const T& root);
// template <typename T> bool connected(const Graph<T>& graph);
// template <typename T> bool circular(const Graph<T>& graph);
// template <typename T> typename std::vector<T> path(const Graph<T>& graph, const T& a, const T& b);
// definitions
// Edge // Edge
@ -191,11 +178,9 @@ size_t Graph<T>::numberOfVertices() const
template <typename T> template <typename T>
size_t Graph<T>::numberOfEdges() const size_t Graph<T>::numberOfEdges() const
{ {
size_t retval = 0; return std::accumulate(m_vertices.begin(), m_vertices.end(), 0,
std::accumulate(m_vertices.begin(), m_vertices.end(), retval, [](int sum, const Vertex& v)
[](size_t sum, const Vertex& v)
{ return sum + v.m_edges.size(); }); { return sum + v.m_edges.size(); });
return retval;
} }
template <typename T> template <typename T>
@ -304,13 +289,6 @@ std::vector<int> Graph<T>::edgesBetween(const T& source, const T& destination) c
} }
template <typename T>
std::string Graph<T>::serialize() const
{
/// @todo implement me
return std::string("");
}
template <typename T> template <typename T>
typename std::vector<typename Graph<T>::Vertex >::const_iterator Graph<T>::find(const T& data) const typename std::vector<typename Graph<T>::Vertex >::const_iterator Graph<T>::find(const T& data) const
{ {
@ -328,61 +306,4 @@ typename std::vector<typename Graph<T>::Vertex >::iterator Graph<T>::find(const
} }
/*
template <typename T>
typename std::vector<T> subtee_breathFirst(const Graph<T>& graph, const T& root)
{
std::vector<T> retval;
std::vector<T> q;
q.push_back(root);
while (!q.empty()) {
T node = q.front();
q.pop_front();
retval.push_back(node);
const std::vector<T> neighbours = graph.neighbours(node);
typename std::vector<T>::const_iterator it;
for (it = neighbours.begin(); it != neighbours.end(); ++it)
q.push_back(*it);
}
return retval;
}
template <typename T>
bool connected(const Graph<T>& graph)
{
std::vector<T> connected;
const std::vector<T> vertices = graph.vertices();
typename std::vector<T>::const_iterator it;
for (it = vertices.begin(); it != vertices.end(); ++it) {
const std::vector<T> neighbours = graph.neighbours(*it);
typename std::vector<T>::const_iterator it2;
for (it2 = neighbours.begin(); it2 != neighbours.end(); ++it2)
connected.push_back(*it2);
}
typename std::vector<T>::const_iterator last = std::unique(connected.begin(), connected.end());
return graph.size == std::distance(connected.begin(), last);
}
template <typename T>
bool circular(const Graph<T>& graph)
{
/// @todo implemente me
return true;
}
template <typename T>
typename std::vector<T> path(const Graph<T>& graph, const T& a, const T& b)
{
// Dijkstra's algorithm for single-source shortest path
/// @todo implemente me
return 0;
}
*/
#endif // GRAPH_H #endif // GRAPH_H

@ -29,6 +29,7 @@ int main()
assert(g.numberOfEdges() == 0); assert(g.numberOfEdges() == 0);
assert(g.addEdge(a, b) == true); assert(g.addEdge(a, b) == true);
assert(g.numberOfEdges() == 1); assert(g.numberOfEdges() == 1);
assert(g.edgesBetween(2, 5).size() == 1); assert(g.edgesBetween(2, 5).size() == 1);

Loading…
Cancel
Save