|
| 1 | +#include <stdlib.h> |
| 2 | +#include <stdio.h> |
| 3 | +#include "../include/undirected_weighted_graph2.h" |
| 4 | + |
| 5 | +int main() { |
| 6 | + |
| 7 | +// char *command = "make run_tests"; |
| 8 | +// int executed = system(command); |
| 9 | +// if (executed != 0) return EXIT_FAILURE; |
| 10 | + |
| 11 | + UndirectedWeightedGraph2 *uwg = UndirectedWeightedGraph2_create(); |
| 12 | + int a = 1, b = 2, c = 3; |
| 13 | + UndirectedWeightedGraph2_insert_Vertex(uwg, &a); |
| 14 | + UndirectedWeightedGraph2_insert_Vertex(uwg, &b); |
| 15 | + UndirectedWeightedGraph2_insert_Vertex(uwg, &c); |
| 16 | + |
| 17 | + UndirectedWeightedGraph2_add_Edge(uwg, 0, 1, 1.1); |
| 18 | + UndirectedWeightedGraph2_add_Edge(uwg, 0, 2, 2.2); |
| 19 | + UndirectedWeightedGraph2_add_Edge(uwg, 1, 2, 3.3); |
| 20 | + |
| 21 | + float edge_0_1 = UndirectedWeightedGraph2_get_weight(uwg, 0, 1); |
| 22 | + float edge_0_2 = UndirectedWeightedGraph2_get_weight(uwg, 0, 2); |
| 23 | + float edge_1_2 = UndirectedWeightedGraph2_get_weight(uwg, 1, 2); |
| 24 | + |
| 25 | + printf("Edge(0, 1): %f\n", edge_0_1); |
| 26 | + printf("Edge(0, 2): %f\n", edge_0_2); |
| 27 | + printf("Edge(1, 2): %f\n", edge_1_2); |
| 28 | + |
| 29 | + int d = 4, e = 5; |
| 30 | + UndirectedWeightedGraph2_insert_Vertex(uwg, &d); |
| 31 | + UndirectedWeightedGraph2_insert_Vertex(uwg, &e); |
| 32 | + UndirectedWeightedGraph2_add_Edge(uwg, 3, 0, 4.4); |
| 33 | + UndirectedWeightedGraph2_add_Edge(uwg, 3, 1, 4.4); |
| 34 | + UndirectedWeightedGraph2_add_Edge(uwg, 3, 2, 4.4); |
| 35 | + |
| 36 | + float edge_0_1_p = UndirectedWeightedGraph2_get_weight(uwg, 0, 1); |
| 37 | + float edge_0_2_p = UndirectedWeightedGraph2_get_weight(uwg, 0, 2); |
| 38 | + float edge_1_2_p = UndirectedWeightedGraph2_get_weight(uwg, 1, 2); |
| 39 | + float edge_0_3 = UndirectedWeightedGraph2_get_weight(uwg, 3, 0); |
| 40 | + float edge_1_3 = UndirectedWeightedGraph2_get_weight(uwg, 3, 1); |
| 41 | + float edge_2_3 = UndirectedWeightedGraph2_get_weight(uwg, 3, 2); |
| 42 | + |
| 43 | + printf("Edge(0, 1): %f\n", edge_0_1_p); |
| 44 | + printf("Edge(0, 2): %f\n", edge_0_2_p); |
| 45 | + printf("Edge(1, 2): %f\n", edge_1_2_p); |
| 46 | + printf("Edge(0, 3): %f\n", edge_0_3); |
| 47 | + printf("Edge(1, 3): %f\n", edge_1_3); |
| 48 | + printf("Edge(2, 3): %f\n", edge_2_3); |
| 49 | + |
| 50 | + UndirectedWeightedGraph2_add_Edge(uwg, 3, 2, 4.4); |
| 51 | + |
| 52 | + UndirectedWeightedGraph2_set_weight(uwg, 3, 2, 99.99); |
| 53 | + float edge_2_3_p = UndirectedWeightedGraph2_get_weight(uwg, 3, 2); |
| 54 | + printf("Edge(2, 3): %f\n", edge_2_3_p); |
| 55 | + |
| 56 | + float edge_0_2_p_p = UndirectedWeightedGraph2_get_weight(uwg, 2, 0); |
| 57 | + printf("Edge(0, 2): %f\n", edge_0_2_p_p); |
| 58 | + |
| 59 | + UndirectedWeightedGraph2_remove_Edge(uwg, 0, 2); |
| 60 | + float edge_0_2_p_p_p = UndirectedWeightedGraph2_get_weight(uwg, 0, 2); |
| 61 | + printf("Edge(0, 2): %f\n", edge_0_2_p_p_p); |
| 62 | + |
| 63 | + float edge_0_1_p_ = UndirectedWeightedGraph2_get_weight(uwg, 0, 1); |
| 64 | + float edge_0_2_p_ = UndirectedWeightedGraph2_get_weight(uwg, 0, 2); |
| 65 | + float edge_0_3_p_ = UndirectedWeightedGraph2_get_weight(uwg, 0, 3); |
| 66 | + printf("Edge(0, 1): %f\n", edge_0_1_p_); |
| 67 | + printf("Edge(0, 2): %f\n", edge_0_2_p_); |
| 68 | + printf("Edge(0, 3): %f\n", edge_0_3_p_); |
| 69 | + UndirectedWeightedGraph2_remove_Vertex(uwg, 0); |
| 70 | + float edge_0_1_p__ = UndirectedWeightedGraph2_get_weight(uwg, 0, 1); |
| 71 | + float edge_0_2_p__ = UndirectedWeightedGraph2_get_weight(uwg, 0, 2); |
| 72 | + float edge_0_3_p__ = UndirectedWeightedGraph2_get_weight(uwg, 0, 3); |
| 73 | + printf("Edge(0, 1): %f\n", edge_0_1_p__); |
| 74 | + printf("Edge(0, 2): %f\n", edge_0_2_p__); |
| 75 | + printf("Edge(0, 3): %f\n", edge_0_3_p__); |
| 76 | + |
| 77 | + return EXIT_SUCCESS; |
| 78 | +} |
0 commit comments