Welcome to my solutions for Advent of Code 2020! Below are some of my thoughts about any days which I found particularly interesting or challenging, and also some nice animations as a reward if you make it that far. Enjoy!
- Day 7 (the one with all the bags) was the first one which I found challenging. I counted the shiny gold bag as being inside itself for a while, which didn't help 🤦♂️. But a really fun problem.
- Day 8 (the console boot code one) had a really interesting part 2, where we had to flip one of the instructions to fix the code. I'm a little ashamed to admit I just brute forced this one, instead of using a more clever Ariadne's string type approach. That would certainly have been faster, but the input was small enough that I could get away with it.
- Day 11 (the one with the ferry terminal seats) was the first of a few "Game of Life" style problems this year. Very enjoyable and produces some cool animations (see below).
- Day 14 (the bitmask one). I found this one particularly fiddly, especially part 2, and I'm not really pleased with the highly suspect way I loop through the memory addresses.
- Day 15 (the memory recital game one). I wrote my code for part 1, tried it on the much larger input in part 2, and after waiting for a while with no result, decided it needed some optimising. I did it the best way that I could think of, and while it isn't fast, it gets the job done. Also, my code ended up being only 15 lines long - the shortest for any day by quite a margin.
- Day 16 (the train ticket one) and Day 21 (the allergen one) were 2 quite similar days. Deciding which category is which on the train ticket is a closely related problem to figuring out which ingredient contains which allergen. No surprise then that my code for solving each of these felt equally long-winded and clumsy, although I still enjoyed solving them both.
- Day 18 (the one with the maths homework). This was definitely one of my favourite days. Both parts were really interesting, and it makes you realise just how accustomed we (and also computers) are to the ways in which maths works, and how tricky it is to tell a computer to forget those things and do it a different way. I was also pretty happy with the recursive solution that I got to work surprisingly quickly.
- Day 19 (the message validation one) was another one of my favourites. It too involved a fairly complex recursive solution, and it took me a lot of tweaking and debugging to get the right answer for the first part. When I saw the second part introduced infinite loops, I feared I might have to rewrite the whole thing (as frequently happens), but fortunately my original code worked straight away. It's not often that happens, so you've got to celebrate the wins when you can! 🥳
- Day 20 (the sea monster one). This was a real marathon of a problem. It took me the longest of any day to do, and also needed the most code, coming in at just under 200 lines! It's not every day that you get to search for sea monsters though, so I'm definitely not complaining.
- Day 22 (the card game one) was another recursion problem that I really enjoyed. I think part of the reason I like these problems is that their solutions can be very powerful and elegant, and the rest is my surprised delight when my code actually runs successfully.
- Day 23 (the cups one). I spent quite a while trying to speed my code up for this one, but the result was still slow, so I'm fairly sure I'm missing something here.
- Day 24 (the one with the hexagonal lobby tiles) was another problem which gave us some nice animations (see below).
There were a couple of days in this year's Advent of Code which I thought gave particularly nice animations. The first of them was day 11, where ferry passengers were getting in and out of seats based on the number of people around them. This is my animation of part 1, where a person will leave a seat if they are surrounded by 4 or more people:
But why does it have to be 4? What happens if we choose a higher or lower number? As it turns out, there is good reason why we shouldn't choose a lower number. But it is interesting to see how it behaves if we set the limit to 5, 6, 7, or 8. The first thing to notice is that it converges a lot quicker - only 11 iterations for the case with a limit of 5 compared to 81 in the original case with a limit of 4! And if we go all the way to 8, it only takes 4 steps:
But whichever number we choose, the behaviour is qualitatively similar, since the passengers can only "see" people sat directly next to them. This means that the events in any given area are independent from what is happening elsewhere, and so we do not see any global patterns emerging.
Then we come to part 2, where our passengers can now see an unlimited distance in any direction. However they are more tolerant now, and will only leave their seat if they can see 5 or more people. Again there is a good reason for this - if you're wondering why then try it with 4 and see what happens! And when we look we see that a pattern appears - a square tilted on its side:
It would be reasonable to think that changing the limit from 5 to 6 wouldn't change things that much - maybe it will just converge a bit quicker like last time, right? Wrong. If you predicted that this would happen, then very well done!
Our square has managed to rotate itself and is now the right way up. The case with 7 is very similar to 6 - we get a regular square getting progressively smaller. But when we increase one more to 8, it just tips it over the edge and our square is no longer stable. So while it starts out as a square, it quickly turns into something resembling a map from one of the old Pokémon games. Or a butterfly. Or something else? I'll let you decide...
Day 24 involved us helping to simulate the Game of Life on the hexagonal floor tiles of a hotel lobby. What fun! I couldn't simply do this problem, count the tiles and not see it brought to life, so here it is: