Fixed indentation

main
Benjamin Kraft 1 year ago
parent 3223948f51
commit bfa9abdc5c
  1. 25
      src/days/01/Day01.cpp
  2. 12
      src/days/02/Day02.cpp
  3. 40
      src/days/03/Day03.cpp
  4. 22
      src/days/04/Day04.cpp
  5. 24
      src/days/05/Day05.cpp
  6. 13
      src/days/05/Day05.h
  7. 9
      src/main.cpp
  8. 18
      src/util.cpp
  9. 8
      src/util.h

@ -2,12 +2,13 @@
Result Day01::Task1() { Result Day01::Task1() {
uint32_t sum = 0; uint32_t sum = 0;
for (const string& line : input){ for (const string &line: input) {
uint8_t left = *std::find_if(line.begin(), line.end(), [](const char c){ uint8_t left = *std::find_if(line.begin(), line.end(), [](const char c) {
int diff = c - '0'; int diff = c - '0';
return diff >= 0 && diff < 10; return diff >= 0 && diff < 10;
}) - '0'; }) - '0';
uint8_t right = *std::find_if(std::make_reverse_iterator(line.end()), std::make_reverse_iterator(line.begin()), [](const char c){ uint8_t right = *std::find_if(std::make_reverse_iterator(line.end()), std::make_reverse_iterator(line.begin()),
[](const char c) {
int diff = c - '0'; int diff = c - '0';
return diff >= 0 && diff < 10; return diff >= 0 && diff < 10;
}) - '0'; }) - '0';
@ -31,20 +32,20 @@ Result Day01::Task2() {
{"nine", '9'}, {"nine", '9'},
}; };
for (const string &line : input){ for (const string &line: input) {
uint8_t left = 0, right = 0; uint8_t left = 0, right = 0;
for (size_t i = 0; i < line.length(); i++){ for (size_t i = 0; i < line.length(); i++) {
auto current = line.substr(0, i + 1); auto current = line.substr(0, i + 1);
auto diff = current.back() - '0'; auto diff = current.back() - '0';
if (diff > 0 && diff < 10){ if (diff > 0 && diff < 10) {
left = diff; left = diff;
break; break;
} }
bool found = false; bool found = false;
for (const auto& [key, value] : convert){ for (const auto &[key, value]: convert) {
auto pos = current.find(key); auto pos = current.find(key);
if (pos != string::npos){ if (pos != string::npos) {
left = value - '0'; left = value - '0';
found = true; found = true;
break; break;
@ -53,17 +54,17 @@ Result Day01::Task2() {
if (found) break; if (found) break;
} }
for (size_t i = 0; i < line.length(); i++){ for (size_t i = 0; i < line.length(); i++) {
auto current = line.substr(line.length() - i - 1); auto current = line.substr(line.length() - i - 1);
auto diff = current.front() - '0'; auto diff = current.front() - '0';
if (diff > 0 && diff < 10){ if (diff > 0 && diff < 10) {
right = diff; right = diff;
break; break;
} }
bool found = false; bool found = false;
for (const auto& [key, value] : convert){ for (const auto &[key, value]: convert) {
auto pos = current.find(key); auto pos = current.find(key);
if (pos != string::npos){ if (pos != string::npos) {
right = value - '0'; right = value - '0';
found = true; found = true;
break; break;

@ -7,9 +7,9 @@ Result Day02::Task1() {
uint32_t sum = 0; uint32_t sum = 0;
uint32_t id = 1; uint32_t id = 1;
for (const Game &game : parseGames()){ for (const Game &game: parseGames()) {
bool possible = true; bool possible = true;
for (const auto &set : game) for (const auto &set: game)
if (set[0] > r || set[1] > g || set[2] > b) if (set[0] > r || set[1] > g || set[2] > b)
possible = false; possible = false;
if (possible) if (possible)
@ -22,9 +22,9 @@ Result Day02::Task1() {
Result Day02::Task2() { Result Day02::Task2() {
uint32_t sum = 0; uint32_t sum = 0;
for (const Game &game : parseGames()){ for (const Game &game: parseGames()) {
size_t r = 0, g = 0, b = 0; size_t r = 0, g = 0, b = 0;
for (const auto &set : game){ for (const auto &set: game) {
r = std::max(r, set[0]); r = std::max(r, set[0]);
g = std::max(g, set[1]); g = std::max(g, set[1]);
b = std::max(b, set[2]); b = std::max(b, set[2]);
@ -36,14 +36,14 @@ Result Day02::Task2() {
vector<Day02::Game> Day02::parseGames() const { vector<Day02::Game> Day02::parseGames() const {
vector<Game> games; vector<Game> games;
for (const string &line : input){ for (const string &line: input) {
auto record = line.substr(line.find(": ") + 1); auto record = line.substr(line.find(": ") + 1);
record.push_back(';'); record.push_back(';');
auto setIndices = findAll(record, ";"); auto setIndices = findAll(record, ";");
Game game; Game game;
size_t start = 0; size_t start = 0;
for (size_t i : setIndices){ for (size_t i: setIndices) {
auto set = record.substr(start, i - start); auto set = record.substr(start, i - start);
auto findNumber = [set](const string &type) -> size_t { auto findNumber = [set](const string &type) -> size_t {

@ -5,21 +5,21 @@ Result Day03::Task1() {
auto isSymbol = [this](int32_t x, int32_t y) -> bool { auto isSymbol = [this](int32_t x, int32_t y) -> bool {
if (x < 0 || x > input[0].length() - 1 || if (x < 0 || x > input[0].length() - 1 ||
y < 0 || y > input.size() - 1){ y < 0 || y > input.size() - 1) {
return false; return false;
} }
char c = input[y][x]; char c = input[y][x];
return !isDigit(c) && c != '.'; return !isDigit(c) && c != '.';
}; };
for (const auto &[number, position] : parseEngineNumbers()){ for (const auto &[number, position]: parseEngineNumbers()) {
auto &[value, size] = number; auto &[value, size] = number;
auto &[x, y] = position; auto &[x, y] = position;
bool symbolFound = false; bool symbolFound = false;
for (int32_t sx = x - 1; sx < x + size + 1; sx++){ for (int32_t sx = x - 1; sx < x + size + 1; sx++) {
for (int32_t sy = y - 1; sy < y + 2; sy++){ for (int32_t sy = y - 1; sy < y + 2; sy++) {
if (isSymbol(sx, sy)){ if (isSymbol(sx, sy)) {
symbolFound = true; symbolFound = true;
break; break;
} }
@ -39,20 +39,20 @@ Result Day03::Task2() {
auto isStar = [this](int32_t x, int32_t y) -> bool { auto isStar = [this](int32_t x, int32_t y) -> bool {
if (x < 0 || x > input[0].length() - 1 || if (x < 0 || x > input[0].length() - 1 ||
y < 0 || y > input.size() - 1){ y < 0 || y > input.size() - 1) {
return false; return false;
} }
return input[y][x] == '*'; return input[y][x] == '*';
}; };
for (const auto &[number, position] : parseEngineNumbers()){ for (const auto &[number, position]: parseEngineNumbers()) {
auto &[value, size] = number; auto &[value, size] = number;
auto &[x, y] = position; auto &[x, y] = position;
for (int32_t sx = x - 1; sx < x + size + 1; sx++){ for (int32_t sx = x - 1; sx < x + size + 1; sx++) {
for (int32_t sy = y - 1; sy < y + 2; sy++){ for (int32_t sy = y - 1; sy < y + 2; sy++) {
if (isStar(sx, sy)){ if (isStar(sx, sy)) {
if (stars.contains({sx, sy})){ if (stars.contains({sx, sy})) {
stars[{sx, sy}].insert({number, position}); stars[{sx, sy}].insert({number, position});
} else { } else {
stars[{sx, sy}] = {{number, position}}; stars[{sx, sy}] = {{number, position}};
@ -62,8 +62,8 @@ Result Day03::Task2() {
} }
} }
for (auto &[position, numbers] : stars){ for (auto &[position, numbers]: stars) {
if (numbers.size() == 2){ if (numbers.size() == 2) {
sum += numbers.begin()->first.first * (++numbers.begin())->first.first; sum += numbers.begin()->first.first * (++numbers.begin())->first.first;
} }
} }
@ -74,23 +74,25 @@ Result Day03::Task2() {
vector<Day03::EngineNumber> Day03::parseEngineNumbers() const { vector<Day03::EngineNumber> Day03::parseEngineNumbers() const {
vector<EngineNumber> numbers; vector<EngineNumber> numbers;
for (size_t y = 0; y < input.size(); y++){ for (size_t y = 0; y < input.size(); y++) {
const string& line = input[y]; const string &line = input[y];
uint32_t value = 0; uint32_t value = 0;
uint8_t valueLength = 0; uint8_t valueLength = 0;
bool readingValue = false; bool readingValue = false;
for (size_t x = 0; x < line.length(); x++){ for (size_t x = 0; x < line.length(); x++) {
uint8_t digit; uint8_t digit;
if (isDigit(line[x], digit)){ if (isDigit(line[x], digit)) {
value = value * 10 + digit; value = value * 10 + digit;
valueLength++; valueLength++;
readingValue = true; readingValue = true;
if (x == line.length() - 1) if (x == line.length() - 1)
numbers.push_back({{value, valueLength}, {x - valueLength, y}}); numbers.push_back({{value, valueLength},
{x - valueLength, y}});
} else { } else {
if (readingValue) if (readingValue)
numbers.push_back({{value, valueLength}, {x - valueLength, y}}); numbers.push_back({{value, valueLength},
{x - valueLength, y}});
readingValue = false; readingValue = false;
valueLength = 0; valueLength = 0;
value = 0; value = 0;

@ -4,10 +4,11 @@
Result Day04::Task1() { Result Day04::Task1() {
uint64 sum = 0; uint64 sum = 0;
for (const auto &[winning, having] : parseCards()){ for (const auto &[winning, having]: parseCards()) {
std::set<uint8_t> result; std::set<uint8_t> result;
std::set_intersection(winning.begin(), winning.end(), having.begin(), having.end(), std::inserter(result, result.begin())); std::set_intersection(winning.begin(), winning.end(), having.begin(), having.end(),
if (!result.empty()){ std::inserter(result, result.begin()));
if (!result.empty()) {
sum += uint64(powl(2, result.size() - 1)); sum += uint64(powl(2, result.size() - 1));
} }
} }
@ -18,23 +19,24 @@ Result Day04::Task1() {
Result Day04::Task2() { Result Day04::Task2() {
vector<uint64> matches; vector<uint64> matches;
for (const auto &[winning, having] : parseCards()){ for (const auto &[winning, having]: parseCards()) {
std::set<uint8_t> result; std::set<uint8_t> result;
std::set_intersection(winning.begin(), winning.end(), having.begin(), having.end(), std::inserter(result, result.begin())); std::set_intersection(winning.begin(), winning.end(), having.begin(), having.end(),
std::inserter(result, result.begin()));
matches.push_back(result.size()); matches.push_back(result.size());
} }
vector<uint64> counts(matches.size(), 1); vector<uint64> counts(matches.size(), 1);
for (size_t i = 0; i < matches.size(); i++){ for (size_t i = 0; i < matches.size(); i++) {
for (size_t instance = 0; instance < counts[i]; instance++){ for (size_t instance = 0; instance < counts[i]; instance++) {
for (size_t k = 0; k < matches[i]; k++){ for (size_t k = 0; k < matches[i]; k++) {
counts[i + k + 1]++; counts[i + k + 1]++;
} }
} }
} }
uint64 sum = std::reduce(counts.begin(), counts.end(), 0, [](uint64 a, uint64 b){return a + b;}); uint64 sum = std::reduce(counts.begin(), counts.end(), 0, [](uint64 a, uint64 b) { return a + b; });
return to_string(sum); return to_string(sum);
} }
@ -42,7 +44,7 @@ Result Day04::Task2() {
vector<Day04::Card> Day04::parseCards() const { vector<Day04::Card> Day04::parseCards() const {
vector<Card> cards; vector<Card> cards;
for (string line : input){ for (string line: input) {
line = line.substr(line.find(':') + 1); line = line.substr(line.find(':') + 1);
string left = line.substr(0, line.find(" |")); string left = line.substr(0, line.find(" |"));
string right = line.substr(line.find(" |") + 2); string right = line.substr(line.find(" |") + 2);

@ -6,9 +6,9 @@ Result Day05::Task1() {
uint64 min = UINT64_MAX; uint64 min = UINT64_MAX;
for (uint64 seed : seeds){ for (uint64 seed: seeds) {
uint64 result = seed; uint64 result = seed;
for (const Map &map : maps) for (const Map &map: maps)
result = map.get(result); result = map.get(result);
min = std::min(min, result); min = std::min(min, result);
} }
@ -22,17 +22,17 @@ Result Day05::Task2() {
uint64 min = UINT64_MAX; uint64 min = UINT64_MAX;
for (size_t i = 0; i < seeds.size(); i += 2){ for (size_t i = 0; i < seeds.size(); i += 2) {
vector<Range> resultRanges {Range(seeds[i], seeds[i] + seeds[i + 1] - 1)}; vector<Range> resultRanges{Range(seeds[i], seeds[i] + seeds[i + 1] - 1)};
for (const Map &map : maps){ for (const Map &map: maps) {
vector<Range> newRanges; vector<Range> newRanges;
for (const Range &range : resultRanges) { for (const Range &range: resultRanges) {
auto add = map.get(range); auto add = map.get(range);
std::copy(add.begin(), add.end(), std::back_inserter(newRanges)); std::copy(add.begin(), add.end(), std::back_inserter(newRanges));
} }
resultRanges = newRanges; resultRanges = newRanges;
} }
for (const Range &range : resultRanges) for (const Range &range: resultRanges)
min = std::min(min, range.start); min = std::min(min, range.start);
} }
@ -43,7 +43,7 @@ vector<uint64> Day05::parseSeeds() const {
vector<uint64> seeds; vector<uint64> seeds;
auto list = (input[0] + " ").substr(7); auto list = (input[0] + " ").substr(7);
size_t start = 0; size_t start = 0;
for (size_t i : findAll(list, " ")){ for (size_t i: findAll(list, " ")) {
seeds.push_back(std::stoul(list.substr(start, i - start))); seeds.push_back(std::stoul(list.substr(start, i - start)));
start = i; start = i;
} }
@ -56,9 +56,9 @@ std::array<Day05::Map, 7> Day05::parseMaps() const {
size_t map = 0; size_t map = 0;
for (size_t i = 3; i < input.size(); i++){ for (size_t i = 3; i < input.size(); i++) {
string line = input[i]; string line = input[i];
if (line.empty()){ if (line.empty()) {
i++; i++;
map++; map++;
continue; continue;
@ -91,7 +91,7 @@ bool Day05::Mapping::touchesRange(Day05::Range src) const {
uint64 Day05::Map::get(uint64 src) const { uint64 Day05::Map::get(uint64 src) const {
for (const Mapping &mapping : mappings) for (const Mapping &mapping: mappings)
if (mapping.containsKey(src)) if (mapping.containsKey(src))
return mapping.get(src); return mapping.get(src);
return src; return src;
@ -109,7 +109,7 @@ vector<Day05::Range> Day05::Map::get(Day05::Range src) const {
if (src.end > maxSource) if (src.end > maxSource)
ranges.emplace_back(maxSource + 1, src.end); ranges.emplace_back(maxSource + 1, src.end);
for (const Mapping &mapping : mappings) for (const Mapping &mapping: mappings)
if (mapping.touchesRange(src)) if (mapping.touchesRange(src))
ranges.emplace_back(mapping.get(src)); ranges.emplace_back(mapping.get(src));

@ -7,26 +7,37 @@ class Day05 : public Day {
uint64 start; uint64 start;
uint64 end; uint64 end;
}; };
struct Mapping { struct Mapping {
uint64 destination; uint64 destination;
uint64 source; uint64 source;
uint64 range; uint64 range;
bool containsKey(uint64 src) const; bool containsKey(uint64 src) const;
uint64 get(uint64 src) const; uint64 get(uint64 src) const;
bool touchesRange(Range src) const; bool touchesRange(Range src) const;
Range get(Range src) const; Range get(Range src) const;
bool operator <(const Mapping &other) const;
bool operator<(const Mapping &other) const;
}; };
struct Map { struct Map {
set<Mapping> mappings; set<Mapping> mappings;
uint64 get(uint64 src) const; uint64 get(uint64 src) const;
vector<Range> get(Range src) const; vector<Range> get(Range src) const;
}; };
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
vector<uint64> parseSeeds() const; vector<uint64> parseSeeds() const;
std::array<Map, 7> parseMaps() const; std::array<Map, 7> parseMaps() const;
}; };

@ -14,8 +14,8 @@ Input getInput(int day, string key, bool useTestInput, int testFetchIndex) {
string dayStr = std::to_string(day); string dayStr = std::to_string(day);
string url = "https://adventofcode.com/2023/day/" + dayStr; string url = "https://adventofcode.com/2023/day/" + dayStr;
auto cookies = cpr::Cookies{{"session", key}}; auto cookies = cpr::Cookies{{"session", key}};
if (!useTestInput){ if (!useTestInput) {
if (key.empty()){ if (key.empty()) {
cout << "Session key Cookie is missing, cannot fetch Input" << endl; cout << "Session key Cookie is missing, cannot fetch Input" << endl;
return input; return input;
} }
@ -25,7 +25,8 @@ Input getInput(int day, string key, bool useTestInput, int testFetchIndex) {
file << cpr::Get(cpr::Url{url}, cookies).text; file << cpr::Get(cpr::Url{url}, cookies).text;
file.close(); file.close();
} else { } else {
cout << "Test Input does not exist. Fetching from " + url << " from <code>-Tag with index " << testFetchIndex << endl; cout << "Test Input does not exist. Fetching from " + url << " from <code>-Tag with index "
<< testFetchIndex << endl;
std::ofstream file(localFilePath); std::ofstream file(localFilePath);
string res = cpr::Get(cpr::Url{url}).text; string res = cpr::Get(cpr::Url{url}).text;
size_t i1 = findAll(res, "<code>")[testFetchIndex]; size_t i1 = findAll(res, "<code>")[testFetchIndex];
@ -59,7 +60,7 @@ string getSessionKey() {
return key; return key;
} }
void parseArgument(const string& arg, int &dayNum, bool &useTestInput, int &testFetchIndex){ void parseArgument(const string &arg, int &dayNum, bool &useTestInput, int &testFetchIndex) {
size_t tIndex = arg.find('T'); size_t tIndex = arg.find('T');
if (tIndex == string::npos) { if (tIndex == string::npos) {
dayNum = stoi(arg); dayNum = stoi(arg);

@ -1,11 +1,11 @@
#include "util.h" #include "util.h"
vector<size_t> findAll(const string& data, const string& toSearch){ vector<size_t> findAll(const string &data, const string &toSearch) {
vector<size_t> indices; vector<size_t> indices;
size_t pos = data.find(toSearch); size_t pos = data.find(toSearch);
while (pos != string::npos){ while (pos != string::npos) {
indices.push_back(pos); indices.push_back(pos);
pos = data.find(toSearch, pos + toSearch.size()); pos = data.find(toSearch, pos + toSearch.size());
@ -14,17 +14,17 @@ vector<size_t> findAll(const string& data, const string& toSearch){
return indices; return indices;
} }
void removeAll(string& data, const string& toRemove) { void removeAll(string &data, const string &toRemove) {
vector<size_t> indices = findAll(data, toRemove); vector<size_t> indices = findAll(data, toRemove);
std::sort(indices.rbegin(), indices.rend()); std::sort(indices.rbegin(), indices.rend());
for (size_t &i : indices) for (size_t &i: indices)
data.erase(i, toRemove.size()); data.erase(i, toRemove.size());
} }
vector<string> split(const string& data, const char c){ vector<string> split(const string &data, const char c) {
vector<string> parts; vector<string> parts;
size_t start = 0; size_t start = 0;
for (size_t i : findAll(data, std::string(1, c))){ for (size_t i: findAll(data, std::string(1, c))) {
parts.push_back(data.substr(start, i - start)); parts.push_back(data.substr(start, i - start));
start = i + 1; start = i + 1;
} }
@ -32,16 +32,16 @@ vector<string> split(const string& data, const char c){
return parts; return parts;
} }
bool isDigit(char c, uint8_t& result){ bool isDigit(char c, uint8_t &result) {
auto val = c - '0'; auto val = c - '0';
if (val >= 0 && val < 10){ if (val >= 0 && val < 10) {
result = val; result = val;
return true; return true;
} }
return false; return false;
} }
bool isDigit(char c){ bool isDigit(char c) {
auto val = c - '0'; auto val = c - '0';
return val >= 0 && val < 10; return val >= 0 && val < 10;
} }

@ -20,12 +20,12 @@ using std::string, std::vector, std::pair, std::map;
using std::list, std::set, std::unordered_set; using std::list, std::set, std::unordered_set;
using std::priority_queue; using std::priority_queue;
vector<size_t> findAll(const string& data, const string& toSearch); vector<size_t> findAll(const string &data, const string &toSearch);
void removeAll(string& data, const string& toRemove); void removeAll(string &data, const string &toRemove);
vector<string> split(const string& data, char c); vector<string> split(const string &data, char c);
bool isDigit(char c, uint8_t& result); bool isDigit(char c, uint8_t &result);
bool isDigit(char c); bool isDigit(char c);
Loading…
Cancel
Save