Files
advent-of-code/2017/puzzle-02-02.cc
2021-12-14 07:23:49 +00:00

36 lines
719 B
C++

#include <algorithm>
#include <cstdint>
#include <iostream>
#include <string>
#include <vector>
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;
}