Fixed indentation

main
Benjamin Kraft 1 year ago
parent 3223948f51
commit bfa9abdc5c
  1. 47
      src/days/01/Day01.cpp
  2. 4
      src/days/01/Day01.h
  3. 14
      src/days/02/Day02.cpp
  4. 4
      src/days/02/Day02.h
  5. 42
      src/days/03/Day03.cpp
  6. 4
      src/days/03/Day03.h
  7. 24
      src/days/04/Day04.cpp
  8. 4
      src/days/04/Day04.h
  9. 26
      src/days/05/Day05.cpp
  10. 17
      src/days/05/Day05.h
  11. 4
      src/days/06/Day06.cpp
  12. 4
      src/days/06/Day06.h
  13. 4
      src/days/07/Day07.cpp
  14. 4
      src/days/07/Day07.h
  15. 4
      src/days/08/Day08.cpp
  16. 4
      src/days/08/Day08.h
  17. 4
      src/days/09/Day09.cpp
  18. 4
      src/days/09/Day09.h
  19. 4
      src/days/10/Day10.cpp
  20. 4
      src/days/10/Day10.h
  21. 4
      src/days/11/Day11.cpp
  22. 4
      src/days/11/Day11.h
  23. 4
      src/days/12/Day12.cpp
  24. 4
      src/days/12/Day12.h
  25. 4
      src/days/13/Day13.cpp
  26. 4
      src/days/13/Day13.h
  27. 4
      src/days/14/Day14.cpp
  28. 4
      src/days/14/Day14.h
  29. 4
      src/days/15/Day15.cpp
  30. 4
      src/days/15/Day15.h
  31. 4
      src/days/16/Day16.cpp
  32. 4
      src/days/16/Day16.h
  33. 4
      src/days/17/Day17.cpp
  34. 4
      src/days/17/Day17.h
  35. 4
      src/days/18/Day18.cpp
  36. 4
      src/days/18/Day18.h
  37. 4
      src/days/19/Day19.cpp
  38. 4
      src/days/19/Day19.h
  39. 4
      src/days/20/Day20.cpp
  40. 4
      src/days/20/Day20.h
  41. 4
      src/days/21/Day21.cpp
  42. 4
      src/days/21/Day21.h
  43. 4
      src/days/22/Day22.cpp
  44. 4
      src/days/22/Day22.h
  45. 4
      src/days/23/Day23.cpp
  46. 4
      src/days/23/Day23.h
  47. 4
      src/days/24/Day24.cpp
  48. 4
      src/days/24/Day24.h
  49. 4
      src/days/25/Day25.cpp
  50. 4
      src/days/25/Day25.h
  51. 9
      src/main.cpp
  52. 18
      src/util.cpp
  53. 8
      src/util.h

@ -2,49 +2,50 @@
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';
return diff >= 0 && diff < 10;
}) - '0';
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';
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';
return diff >= 0 && diff < 10;
}) - '0';
sum += left * 10 + right; sum += left * 10 + right;
} }
return to_string(sum); return to_string(sum);
} }
Result Day01::Task2() { Result Day01::Task2() {
uint32_t sum = 0; uint32_t sum = 0;
std::map<string, char> convert = { std::map<string, char> convert = {
{"one", '1'}, {"one", '1'},
{"two", '2'}, {"two", '2'},
{"three", '3'}, {"three", '3'},
{"four", '4'}, {"four", '4'},
{"five", '5'}, {"five", '5'},
{"six", '6'}, {"six", '6'},
{"seven", '7'}, {"seven", '7'},
{"eight", '8'}, {"eight", '8'},
{"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;
@ -75,5 +76,5 @@ Result Day01::Task2() {
sum += left * 10 + right; sum += left * 10 + right;
} }
return to_string(sum); return to_string(sum);
} }

@ -4,7 +4,7 @@
class Day01 : public Day { class Day01 : public Day {
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
}; };

@ -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)
@ -17,14 +17,14 @@ Result Day02::Task1() {
id++; id++;
} }
return to_string(sum); return to_string(sum);
} }
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,9 +5,9 @@
class Day02 : public Day { class Day02 : public Day {
typedef vector<std::array<size_t, 3>> Game; typedef vector<std::array<size_t, 3>> Game;
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
vector<Game> parseGames() const; vector<Game> parseGames() const;
}; };

@ -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;
} }
@ -29,7 +29,7 @@ Result Day03::Task1() {
sum += value; sum += value;
} }
return to_string(sum); return to_string(sum);
} }
Result Day03::Task2() { Result Day03::Task2() {
@ -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;

@ -5,9 +5,9 @@
class Day03 : public Day { class Day03 : public Day {
typedef pair<pair<uint32_t, uint8_t>, pair<int32_t, int32_t>> EngineNumber; typedef pair<pair<uint32_t, uint8_t>, pair<int32_t, int32_t>> EngineNumber;
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
vector<EngineNumber> parseEngineNumbers() const; vector<EngineNumber> parseEngineNumbers() const;
}; };

@ -4,37 +4,39 @@
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));
} }
} }
return to_string(sum); return to_string(sum);
} }
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);

@ -5,9 +5,9 @@
class Day04 : public Day { class Day04 : public Day {
typedef pair<set<uint8_t>, set<uint8_t>> Card; typedef pair<set<uint8_t>, set<uint8_t>> Card;
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
vector<Card> parseCards() const; vector<Card> parseCards() const;
}; };

@ -6,14 +6,14 @@ 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);
} }
return to_string(min); return to_string(min);
} }
Result Day05::Task2() { Result Day05::Task2() {
@ -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;
}; };

@ -1,9 +1,9 @@
#include "Day06.h" #include "Day06.h"
Result Day06::Task1() { Result Day06::Task1() {
return Day::Task1(); return Day::Task1();
} }
Result Day06::Task2() { Result Day06::Task2() {
return Day::Task2(); return Day::Task2();
} }

@ -4,7 +4,7 @@
class Day06 : public Day { class Day06 : public Day {
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
}; };

@ -1,9 +1,9 @@
#include "Day07.h" #include "Day07.h"
Result Day07::Task1() { Result Day07::Task1() {
return Day::Task1(); return Day::Task1();
} }
Result Day07::Task2() { Result Day07::Task2() {
return Day::Task2(); return Day::Task2();
} }

@ -4,7 +4,7 @@
class Day07 : public Day { class Day07 : public Day {
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
}; };

@ -1,9 +1,9 @@
#include "Day08.h" #include "Day08.h"
Result Day08::Task1() { Result Day08::Task1() {
return Day::Task1(); return Day::Task1();
} }
Result Day08::Task2() { Result Day08::Task2() {
return Day::Task2(); return Day::Task2();
} }

@ -4,7 +4,7 @@
class Day08 : public Day { class Day08 : public Day {
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
}; };

@ -1,9 +1,9 @@
#include "Day09.h" #include "Day09.h"
Result Day09::Task1() { Result Day09::Task1() {
return Day::Task1(); return Day::Task1();
} }
Result Day09::Task2() { Result Day09::Task2() {
return Day::Task2(); return Day::Task2();
} }

@ -4,7 +4,7 @@
class Day09 : public Day { class Day09 : public Day {
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
}; };

@ -1,9 +1,9 @@
#include "Day10.h" #include "Day10.h"
Result Day10::Task1() { Result Day10::Task1() {
return Day::Task1(); return Day::Task1();
} }
Result Day10::Task2() { Result Day10::Task2() {
return Day::Task2(); return Day::Task2();
} }

@ -4,7 +4,7 @@
class Day10 : public Day { class Day10 : public Day {
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
}; };

@ -1,9 +1,9 @@
#include "Day11.h" #include "Day11.h"
Result Day11::Task1() { Result Day11::Task1() {
return Day::Task1(); return Day::Task1();
} }
Result Day11::Task2() { Result Day11::Task2() {
return Day::Task2(); return Day::Task2();
} }

@ -4,7 +4,7 @@
class Day11 : public Day { class Day11 : public Day {
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
}; };

@ -1,9 +1,9 @@
#include "Day12.h" #include "Day12.h"
Result Day12::Task1() { Result Day12::Task1() {
return Day::Task1(); return Day::Task1();
} }
Result Day12::Task2() { Result Day12::Task2() {
return Day::Task2(); return Day::Task2();
} }

@ -4,7 +4,7 @@
class Day12 : public Day { class Day12 : public Day {
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
}; };

@ -1,9 +1,9 @@
#include "Day13.h" #include "Day13.h"
Result Day13::Task1() { Result Day13::Task1() {
return Day::Task1(); return Day::Task1();
} }
Result Day13::Task2() { Result Day13::Task2() {
return Day::Task2(); return Day::Task2();
} }

@ -4,7 +4,7 @@
class Day13 : public Day { class Day13 : public Day {
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
}; };

@ -1,9 +1,9 @@
#include "Day14.h" #include "Day14.h"
Result Day14::Task1() { Result Day14::Task1() {
return Day::Task1(); return Day::Task1();
} }
Result Day14::Task2() { Result Day14::Task2() {
return Day::Task2(); return Day::Task2();
} }

@ -4,7 +4,7 @@
class Day14 : public Day { class Day14 : public Day {
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
}; };

@ -1,9 +1,9 @@
#include "Day15.h" #include "Day15.h"
Result Day15::Task1() { Result Day15::Task1() {
return Day::Task1(); return Day::Task1();
} }
Result Day15::Task2() { Result Day15::Task2() {
return Day::Task2(); return Day::Task2();
} }

@ -4,7 +4,7 @@
class Day15 : public Day { class Day15 : public Day {
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
}; };

@ -1,9 +1,9 @@
#include "Day16.h" #include "Day16.h"
Result Day16::Task1() { Result Day16::Task1() {
return Day::Task1(); return Day::Task1();
} }
Result Day16::Task2() { Result Day16::Task2() {
return Day::Task2(); return Day::Task2();
} }

@ -4,7 +4,7 @@
class Day16 : public Day { class Day16 : public Day {
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
}; };

@ -1,9 +1,9 @@
#include "Day17.h" #include "Day17.h"
Result Day17::Task1() { Result Day17::Task1() {
return Day::Task1(); return Day::Task1();
} }
Result Day17::Task2() { Result Day17::Task2() {
return Day::Task2(); return Day::Task2();
} }

@ -4,7 +4,7 @@
class Day17 : public Day { class Day17 : public Day {
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
}; };

@ -1,9 +1,9 @@
#include "Day18.h" #include "Day18.h"
Result Day18::Task1() { Result Day18::Task1() {
return Day::Task1(); return Day::Task1();
} }
Result Day18::Task2() { Result Day18::Task2() {
return Day::Task2(); return Day::Task2();
} }

@ -4,7 +4,7 @@
class Day18 : public Day { class Day18 : public Day {
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
}; };

@ -1,9 +1,9 @@
#include "Day19.h" #include "Day19.h"
Result Day19::Task1() { Result Day19::Task1() {
return Day::Task1(); return Day::Task1();
} }
Result Day19::Task2() { Result Day19::Task2() {
return Day::Task2(); return Day::Task2();
} }

@ -4,7 +4,7 @@
class Day19 : public Day { class Day19 : public Day {
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
}; };

@ -1,9 +1,9 @@
#include "Day20.h" #include "Day20.h"
Result Day20::Task1() { Result Day20::Task1() {
return Day::Task1(); return Day::Task1();
} }
Result Day20::Task2() { Result Day20::Task2() {
return Day::Task2(); return Day::Task2();
} }

@ -4,7 +4,7 @@
class Day20 : public Day { class Day20 : public Day {
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
}; };

@ -1,9 +1,9 @@
#include "Day21.h" #include "Day21.h"
Result Day21::Task1() { Result Day21::Task1() {
return Day::Task1(); return Day::Task1();
} }
Result Day21::Task2() { Result Day21::Task2() {
return Day::Task2(); return Day::Task2();
} }

@ -4,7 +4,7 @@
class Day21 : public Day { class Day21 : public Day {
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
}; };

@ -1,9 +1,9 @@
#include "Day22.h" #include "Day22.h"
Result Day22::Task1() { Result Day22::Task1() {
return Day::Task1(); return Day::Task1();
} }
Result Day22::Task2() { Result Day22::Task2() {
return Day::Task2(); return Day::Task2();
} }

@ -4,7 +4,7 @@
class Day22 : public Day { class Day22 : public Day {
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
}; };

@ -1,9 +1,9 @@
#include "Day23.h" #include "Day23.h"
Result Day23::Task1() { Result Day23::Task1() {
return Day::Task1(); return Day::Task1();
} }
Result Day23::Task2() { Result Day23::Task2() {
return Day::Task2(); return Day::Task2();
} }

@ -4,7 +4,7 @@
class Day23 : public Day { class Day23 : public Day {
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
}; };

@ -1,9 +1,9 @@
#include "Day24.h" #include "Day24.h"
Result Day24::Task1() { Result Day24::Task1() {
return Day::Task1(); return Day::Task1();
} }
Result Day24::Task2() { Result Day24::Task2() {
return Day::Task2(); return Day::Task2();
} }

@ -4,7 +4,7 @@
class Day24 : public Day { class Day24 : public Day {
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
}; };

@ -1,9 +1,9 @@
#include "Day25.h" #include "Day25.h"
Result Day25::Task1() { Result Day25::Task1() {
return Day::Task1(); return Day::Task1();
} }
Result Day25::Task2() { Result Day25::Task2() {
return Day::Task2(); return Day::Task2();
} }

@ -4,7 +4,7 @@
class Day25 : public Day { class Day25 : public Day {
protected: protected:
Result Task1() override; Result Task1() override;
Result Task2() override; Result Task2() override;
}; };

@ -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