TL;DR : The repository with all solutions, before and after I revisit them. List of solutions at the end of this post

Hi everyone!

I am not sure how many of you know about Advent of Code but it's a really fun programming competition that takes place every year in December. I like it a lot, not so much for the competitiveness, but because of the variety of challenges and the quick ramp up in difficulty.

I have tried to live stream my attempts in the past but I know that after a few days life comes in the way so I've decided to try something new this year!

  • I'll record myself as I do the challenges. Even if it takes several sessions
  • I'll time myself and post the quick and dirty first version of the code
  • And then I'll come back with a better version and share what I've learnt from it!

Why do I think this, I hear? For a few reasons:

  • to force myself to go back to the challenges. I usually stop after I have the dirtiest solution. This will help me learn things.
  • So you can learn too. If I learn, maybe you get a fast track to discovering something new too :).
  • To show that even seniors struggle, google stuff! I have 10 years experience, and I google and stumble on the simplest things. And honestly, that's ok :).

Hopefully you can learn some things too! Let's see how long I can keep this going :). Most of my solutions will be in Kotlin!

Don't expect the best solution out there here, I'm not checking what others are doing. If you want the best, I suggest you check the SubReddit.

So, here goes nothing!

The repository with all solutions, before and after I revisit them (final solutions are in the final package).

Solutions entries :

  • Day 1 : zip, and basic OBS tricks
  • Day 2 : regex destructuring!
  • Day 3 : drop, take and filterIndexed
  • Day 4 : require in data classes and flatMapIndexed
  • Day 5 : binary representations and data classes val init

Hope you like it! Don't hesitate to reach out on Twitter if you want to raise issues or ask questions :).

See you tomorrow for day 1!