mirror of
https://github.com/mfocko/blog.git
synced 2024-11-22 13:03:47 +01:00
50 lines
1.7 KiB
C++
50 lines
1.7 KiB
C++
#include <iostream>
|
|
#include <string>
|
|
#include <utility>
|
|
#include <vector>
|
|
|
|
#include "astar.hpp"
|
|
#include "bf.hpp"
|
|
#include "dijkstra.hpp"
|
|
#include "graph.hpp"
|
|
|
|
auto line_to_vector(const std::string& l) -> std::vector<char> {
|
|
return std::vector(l.begin(), l.end());
|
|
}
|
|
|
|
auto main() -> int {
|
|
graph g{std::vector{
|
|
line_to_vector(std::string("#############")),
|
|
line_to_vector(std::string("#..#..*.*.**#")),
|
|
line_to_vector(std::string("##***.....**#")),
|
|
line_to_vector(std::string("#..########.#")),
|
|
line_to_vector(std::string("#...###...#.#")),
|
|
line_to_vector(std::string("#..#...##.#.#")),
|
|
line_to_vector(std::string("#..#.*.#..#.#")),
|
|
line_to_vector(std::string("#....#....#.#")),
|
|
line_to_vector(std::string("########*.*.#")),
|
|
line_to_vector(std::string("#...........#")),
|
|
line_to_vector(std::string("#############")),
|
|
}};
|
|
std::cout << "Normal cost: " << g.normal_cost() << "\n";
|
|
std::cout << "Vortex cost: " << g.vortex_cost() << "\n";
|
|
std::cout << "Graph:\n" << g;
|
|
|
|
// finding the distances from the bottom left corner to the 2 rows above
|
|
auto cost = bf_finite(g, std::make_pair(1, 9), std::make_pair(1, 7));
|
|
std::cout << "[Finite BF] Cost: " << cost << "\n";
|
|
|
|
auto distances = bellman_ford(g, std::make_pair(1, 9));
|
|
std::cout << "[Bellman-Ford] Cost: " << distances[7][1] << "\n";
|
|
|
|
distances = dijkstra(g, std::make_pair(1, 9));
|
|
std::cout << "[Dijkstra] Cost: " << distances[7][1] << "\n";
|
|
|
|
distances = astar(g, std::make_pair(1, 9), [](const auto& u) {
|
|
auto [x, y] = u;
|
|
return std::abs(1 - x) + std::abs(7 - y);
|
|
});
|
|
std::cout << "[A*] Cost: " << distances[7][1] << "\n";
|
|
|
|
return 0;
|
|
}
|