AoC 2024: Day 22

Main thread for Day 22 of the 2024 advent of code. Feel free to discuss the challenge and ask questions. If particular discussions become large, we can break them off into new threads.

Some Rules:

  1. Please try to keep spoilers within spoiler tags. This is done by typing [spoiler]text to be blurred[\spoiler]. If you have longer sections you can also use the [details=“Title”] tags.
  2. Have Fun

Day 22 Challenge

Templates:

Resources:

Previous days discussions

Day 1: AoC 2024: Day 1
Day 2: AoC 2024: Day 2
Day 3: AoC 2024: Day 3
Day 4: AoC 2024: Day 4
Day 5: AoC 2024: Day 5
Day 6: AoC 2024: Day 6
Day 7: AoC 2024: Day 7
Day 8: AoC 2024: Day 8
Day 9: AoC 2024: Day 9
Day 10: AoC 2024: Day 10
Day 11: AoC 2024: Day 11
Day 12: AoC 2024: Day 12
Day 13: AoC 2024: Day 13
Day 14: AoC 2023: Day 14
Day 15: AoC 2024: Day 15
Day 16: AoC 2024: Day 16
Day 17: AoC 2024: Day 17
Day 18: AoC 2024: Day 18
Day 19: AoC 2024: Day 19
Day 20: AoC 2024: Day 20
Day 21: AoC 2024: Day 21

Posting late, but managed to solve this yesterday. Interesting stuff, allowed for both brute force and somewhat more optimized solutions, and then some interesting potential for optimizations. I found Zig support for SIMD a bit lacking, in particular I would expect vector indexing / scatter gather operations to ‘just work’, instead, unfortunately, they are not present at all, even as library calls.
Writing in assembly is not the point here, so part2 hits a bit of a perfromance penalty when doing multi-key lookups and writes.

Source: aoc2024/src/day22.zig at main · p88h/aoc2024 · GitHub
Video: https://youtu.be/N9keS5KF-xU

Benchmark:

        parse   part1   part2   total
day 22:  0.2 ms  0.1 ms  0.8 ms  1.1 ms (+-1%) iter=660

80ms… not super fast but I am happy.

https://zigbin.io/f8a2b1