12
This commit is contained in:
parent
082fa94b8f
commit
39e7c82527
22
12/CMakeLists.txt
Normal file
22
12/CMakeLists.txt
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
cmake_minimum_required(VERSION 3.10)
|
||||||
|
set(CMAKE_CXX_STANDARD 14)
|
||||||
|
set(CMAKE_CXX_STANDARD_REQUIRED True)
|
||||||
|
set(CMAKE_EXPORT_COMPILE_COMMANDS ON)
|
||||||
|
enable_language(CXX)
|
||||||
|
|
||||||
|
project(AoC12)
|
||||||
|
|
||||||
|
if(APPLE)
|
||||||
|
include_directories(/usr/local/include)
|
||||||
|
link_directories(/usr/local/lib)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(WIN32)
|
||||||
|
add_executable(${CMAKE_PROJECT_NAME} WIN32)
|
||||||
|
else()
|
||||||
|
add_executable(${CMAKE_PROJECT_NAME})
|
||||||
|
endif()
|
||||||
|
|
||||||
|
target_sources(${CMAKE_PROJECT_NAME}
|
||||||
|
PRIVATE main.cpp
|
||||||
|
)
|
19
12/input
Normal file
19
12/input
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
lg-GW
|
||||||
|
pt-start
|
||||||
|
pt-uq
|
||||||
|
nx-lg
|
||||||
|
ve-GW
|
||||||
|
start-nx
|
||||||
|
GW-start
|
||||||
|
GW-nx
|
||||||
|
pt-SM
|
||||||
|
sx-GW
|
||||||
|
lg-end
|
||||||
|
nx-SM
|
||||||
|
lg-SM
|
||||||
|
pt-nx
|
||||||
|
end-ve
|
||||||
|
ve-SM
|
||||||
|
TG-uq
|
||||||
|
end-SM
|
||||||
|
SM-uq
|
105
12/main.cpp
Normal file
105
12/main.cpp
Normal file
@ -0,0 +1,105 @@
|
|||||||
|
#include <algorithm>
|
||||||
|
#include <deque>
|
||||||
|
#include <fstream>
|
||||||
|
#include <iostream>
|
||||||
|
#include <sstream>
|
||||||
|
#include <unordered_map>
|
||||||
|
#include <unordered_set>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
|
using GraphMap = std::unordered_map<std::string, std::vector<std::string>>;
|
||||||
|
|
||||||
|
GraphMap getMap(const std::string &file_name) {
|
||||||
|
GraphMap map{};
|
||||||
|
|
||||||
|
std::ifstream file(file_name);
|
||||||
|
std::string str;
|
||||||
|
while (std::getline(file, str)) {
|
||||||
|
auto deliminer = str.find_first_of('-');
|
||||||
|
auto start = str.substr(0, deliminer);
|
||||||
|
auto end = str.substr(deliminer + 1);
|
||||||
|
map[start].push_back(end);
|
||||||
|
map[end].push_back(start);
|
||||||
|
}
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint64_t getPaths(const GraphMap &map, const std::string &start,
|
||||||
|
std::vector<std::string> &visited,
|
||||||
|
#ifdef DEBUG
|
||||||
|
std::vector<std::string> &path,
|
||||||
|
#endif
|
||||||
|
bool can_twice = false, bool has_twice = false) {
|
||||||
|
uint64_t paths = 0;
|
||||||
|
for (const auto &dest : map.at(start)) {
|
||||||
|
if (dest == "start") {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
bool is_twice = false;
|
||||||
|
if (std::find(visited.begin(), visited.end(), dest) != visited.end()) {
|
||||||
|
if (!can_twice || (can_twice && has_twice)) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
has_twice = true;
|
||||||
|
is_twice = true;
|
||||||
|
}
|
||||||
|
if (dest == "end") {
|
||||||
|
paths++;
|
||||||
|
#ifdef DEBUG
|
||||||
|
for (auto &thingy : path) {
|
||||||
|
std::cout << thingy << "->";
|
||||||
|
}
|
||||||
|
std::cout << "end" << std::endl;
|
||||||
|
#endif
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (dest[0] >= 'a' && dest[0] <= 'z' && !is_twice) {
|
||||||
|
visited.push_back(dest);
|
||||||
|
}
|
||||||
|
#ifdef DEBUG
|
||||||
|
path.push_back(dest);
|
||||||
|
paths += getPaths(map, dest, visited, path, can_twice, has_twice);
|
||||||
|
path.pop_back();
|
||||||
|
#endif
|
||||||
|
paths += getPaths(map, dest, visited, can_twice, has_twice);
|
||||||
|
if (dest[0] >= 'a' && dest[0] <= 'z' && !is_twice) {
|
||||||
|
visited.pop_back();
|
||||||
|
}
|
||||||
|
if (is_twice) {
|
||||||
|
has_twice = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return paths;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint64_t part1(const GraphMap &map) {
|
||||||
|
std::vector<std::string> visited{ "start" };
|
||||||
|
#ifdef DEBUG
|
||||||
|
std::vector<std::string> path{ "start" };
|
||||||
|
return getPaths(map, "start", visited, path);
|
||||||
|
#endif
|
||||||
|
return getPaths(map, "start", visited);
|
||||||
|
}
|
||||||
|
|
||||||
|
uint64_t part2(const GraphMap &map) {
|
||||||
|
std::vector<std::string> visited{ "start" };
|
||||||
|
#ifdef DEBUG
|
||||||
|
std::vector<std::string> path{ "start" };
|
||||||
|
return getPaths(map, "start", visited, path, true);
|
||||||
|
#endif
|
||||||
|
return getPaths(map, "start", visited, true);
|
||||||
|
}
|
||||||
|
|
||||||
|
int main(int argc, char **argv) {
|
||||||
|
if (argc < 2) {
|
||||||
|
std::cerr << "You must provide input file!" << std::endl;
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
auto map = getMap(argv[1]);
|
||||||
|
std::cout << "There are \033[91;1m" << part1(map)
|
||||||
|
<< "\033[0m paths in the cave system." << std::endl;
|
||||||
|
std::cout << "There are \033[91;1m" << part2(map)
|
||||||
|
<< "\033[0m paths in the cave system with new rules."
|
||||||
|
<< std::endl;
|
||||||
|
return 0;
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user