Add 2017 day 2 puzzles

This commit is contained in:
2021-12-13 12:11:20 +00:00
parent 020549d323
commit 920bbb283f
2 changed files with 62 additions and 0 deletions

29
2017/puzzle-02-01.cc Normal file
View File

@@ -0,0 +1,29 @@
#include <algorithm>
#include <iostream>
#include <string>
auto main() -> int
{
std::string line;
std::uint64_t checksum{0};
while (std::getline(std::cin, line) && !line.empty()) {
std::vector<std::uint64_t> nums;
std::size_t idx{0};
while (idx < line.size()) {
if (std::iswspace(line[idx]) == 1) {
++idx;
continue;
}
std::size_t end{0};
nums.push_back(std::stoul(line.substr(idx), &end));
idx += end;
}
auto [min, max] = std::minmax_element(nums.begin(), nums.end());
checksum += *max - *min;
}
std::cout << "Checksum: " << checksum << '\n';
return 0;
}

33
2017/puzzle-02-02.cc Normal file
View File

@@ -0,0 +1,33 @@
#include <algorithm>
#include <iostream>
#include <string>
auto main() -> int
{
std::string line;
std::uint64_t checksum{0};
while (std::getline(std::cin, line) && !line.empty()) {
std::vector<std::uint64_t> nums;
std::size_t idx{0};
while (idx < line.size()) {
if (std::iswspace(line[idx]) == 1) {
++idx;
continue;
}
std::size_t end{0};
nums.push_back(std::stoul(line.substr(idx), &end));
idx += end;
}
for (auto n1 : nums) {
for (auto n2 : nums) {
if (n1 != n2 && n1 % n2 == 0)
checksum += n1 / n2;
}
}
}
std::cout << "Checksum: " << checksum << '\n';
return 0;
}