force solution

Change-Id: I1421c6279597b9cb040dfcafb6984a3730503d10
This commit is contained in:
2025-12-09 07:53:44 +01:00
committed by Pratchaya Khansomboon
parent 14ec3ca2da
commit 432a5b1f7c

View File

@@ -56,59 +56,64 @@ R14
L82 L82
)"; )";
enum class rotdir { auto map_char_to_rotdir(char c) -> i32 {
none,
L,
R
};
struct rot {
rotdir dir;
u32 turns;
};
auto map_char_to_rotdir(char c) -> rotdir {
switch (c) { switch (c) {
using enum rotdir; case 'L': return -1;
case 'L': return L; case 'R':
case 'R': return R; default: return 1;
default: return none;
} }
} }
auto map_dir_to_i32(i32 value, rotdir dir) -> i32 {
switch (dir) {
using enum rotdir;
case L: return -value;
case R:
default: return value;
}
}
static auto entry([[maybe_unused]]std::span<char const*> const& args) -> void { static auto entry([[maybe_unused]]std::span<char const*> const& args) -> void {
// std::string str{raw_str}; // std::string str{raw_str};
// str = str | trim; auto str = aoc::read_text("./input.txt").value_or("");
auto str = aoc::read_text("./input.txt").value_or("") | trim; str = str | trim;
auto rot_vec = str | std::views::split("\n"sv) | std::views::transform([](auto const& str) { auto rot_vec = str | std::views::split("\n"sv) | std::views::transform([](auto const& str) {
return rot{ return i32(std::stoi(std::string{++std::begin(str), std::end(str)})) * map_char_to_rotdir(*std::begin(str));
.dir = map_char_to_rotdir(*std::begin(str)),
.turns = u32(std::stoul(std::string{++std::begin(str), std::end(str)}))
};
}) | std::ranges::to<std::vector>(); }) | std::ranges::to<std::vector>();
i32 start = 50; i32 start = 50;
auto sum = std::ranges::fold_left(rot_vec, 0, [&start](auto a, auto b) { i32 zero_cross = 0;
auto c = map_dir_to_i32(b.turns % 100, b.dir); // auto sum = std::ranges::fold_left(rot_vec, 0, [&](auto a, auto t) {
// auto const p = start;
// start = (100 + p - t) % 100;
//
// zero_cross += (std::abs((p - t + 1) % 100) + std::abs(t)) / 100;
//
// fmt::print("pos: {}, next: {}, t: {}\n", p, start, t);
//
// if (start == 0) {
// a += 1;
// }
//
// return a;
// });
start = (100 + start + c) % 100; auto sum = std::ranges::fold_left(rot_vec, 0, [&](auto a, auto t) {
auto const dir = t < 0 ? -1 : 1;
auto const steps = std::abs(t);
if (start == 0) ++a; for (i32 i = 0; i < steps; ++i) {
auto next = start + dir;
if (next < 0) next = 99;
next = next % 100;
if (next % 100 == 0)
++zero_cross;
start = next;
}
if (start % 100 == 0) {
++a;
if (zero_cross > 0)
zero_cross -= 1;
}
return a; return a;
}); });
fmt::print("res: {}\n", sum); fmt::print("res: {}, {} sum = {}\n", sum, zero_cross, sum + zero_cross);
} }
auto main([[maybe_unused]]int argc, [[maybe_unused]]char const* argv[]) -> int { auto main([[maybe_unused]]int argc, [[maybe_unused]]char const* argv[]) -> int {