#include #include #include "graph.h" int main() { Graph g; assert(g.empty() == true); assert(g.numberOfVertices() == 0); assert(g.numberOfEdges() == 0); int a = 2; int b = 5; assert(g.addEdge(a, b) == false); assert(g.addVertex(a) == true); assert(g.addVertex(a) == false); assert(g.empty() == false); assert(g.numberOfVertices() == 1); { const std::vector v = g.vertices(); assert(v.size() == 1); assert(*(v[0]) == 2); } assert(g.addEdge(a, b) == false); assert(g.addVertex(b) == true); assert(g.numberOfVertices() == 2); { const std::vector v = g.vertices(); assert(v.size() == 2); assert(*(v[0]) == 2); assert(*(v[1]) == 5); } assert(g.numberOfEdges() == 0); assert(g.addEdge(a, b) == true); assert(g.numberOfEdges() == 1); { const std::vector eb = g.edgesBetween(2, 5); assert(eb.size() == 1); assert(eb[0] == 0); } assert(g.edgesBetween(5, 2).size() == 0); assert(g.neighboursOf(2).size() == 1); { const std::vector n = g.neighboursOf(2); assert(n.size() == 1); assert(*(n[0]) == 5); } int c = 13; int d = 1; g.addVertex(d); g.addVertex(c); int vertices_array[] = {2, 5, 13, 1}; std::vector v(vertices_array, vertices_array + sizeof(vertices_array) / sizeof(int) ); Graph::vertex_iterator g_it; std::vector::iterator v_it; for (g_it = g.vertex_begin(), v_it = v.begin(); g_it != g.vertex_end(); g_it++, v_it++) assert(*g_it == *v_it); assert(g.neighboursOf(5).size() == 0); Graph g2; g.addVertex(1); g.addVertex(2); g.addVertex(3); g.addVertex(4); int vertices_array2[] = {1, 2, 3, 4}; std::vector v2(vertices_array2, vertices_array2 + sizeof(vertices_array2) / sizeof(int) ); for (g_it = g2.vertex_begin(), v_it = v2.begin(); g_it != g2.vertex_end(); g_it++, v_it++) assert(*g_it == *v_it); assert(g.addEdge(b, c) == true); assert(g.addEdge(a, d) == true); std::vector::Edge> e = g.edges(); assert(e.size() == 3); for(Graph::edge_iterator edge_it = g.edge_begin(); edge_it != g.edge_end(); ++edge_it) { std::cout << (*edge_it).getSource() << " " << (*edge_it).getDestination() << " " << (*edge_it).getWeight() << std::endl; } return 0; }