From cf08978c4e65dc7d06989f7a38c4acbb34ae4bc1 Mon Sep 17 00:00:00 2001 From: eriedaberrie Date: Wed, 18 Dec 2024 21:41:33 -0800 Subject: [PATCH] 2024 day 19 --- 2024/19/main-1.cpp | 40 +++++++++++++++++++++++++++++++++++ 2024/19/main-2.cpp | 52 ++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 92 insertions(+) create mode 100644 2024/19/main-1.cpp create mode 100644 2024/19/main-2.cpp diff --git a/2024/19/main-1.cpp b/2024/19/main-1.cpp new file mode 100644 index 0000000..58677a4 --- /dev/null +++ b/2024/19/main-1.cpp @@ -0,0 +1,40 @@ +#include "../../include/aoc.hpp" +#include +using namespace std; + +vector towels; + +bool rec(string_view s) { + if (s.empty()) { + return true; + } + for (auto &t : towels) { + if (s.starts_with(t) && rec(s.substr(t.size()))) { + return true; + } + } + return false; +} + +int main() { + ios::sync_with_stdio(0); + cin.tie(0); + + string line; + getline(cin, line); + istringstream ll(line); + string s; + while (getline(ll, s, ',')) { + towels.push_back(s); + ll.ignore(); + } + + cin.ignore(); + ull count = 0; + while (getline(cin, line)) { + if (rec(line)) { + count++; + } + } + cout << count << endl; +} diff --git a/2024/19/main-2.cpp b/2024/19/main-2.cpp new file mode 100644 index 0000000..d37053c --- /dev/null +++ b/2024/19/main-2.cpp @@ -0,0 +1,52 @@ +#include "../../include/aoc.hpp" +#include +using namespace std; + +unordered_map m; +vector towels; +vector designs; + +ull rec(string_view s) { + if (s.empty()) { + return 1; + } + if (m.contains(s)) { + return m[s]; + } + ull c = 0; + for (auto &t : towels) { + if (s.starts_with(t)) { + c += rec(s.substr(t.size())); + } + } + m[s] = c; + return c; +} + +int main() { + ios::sync_with_stdio(0); + cin.tie(0); + + string line; + getline(cin, line); + istringstream ll(line); + string s; + while (getline(ll, s, ',')) { + towels.push_back(s); + ll.ignore(); + } + + cin.ignore(); + while (getline(cin, line)) { + designs.push_back(line); + } + + // NOTE: designs gets their own global vector to make sure that the design + // strings live for as long as the memo does (it happened to work on the + // full data the first try without it but don't rely on that) + ull count = 0; + for (string &design : designs) { + count += rec(design); + } + cout << count << endl; +}