This year I'll be solving the advent problems using Kotlin! 🥂
If you're interested in trying out Kotlin for AoC this year or even next, check out this YouTube video from the Kotlin team. They provide helpful tips for Kotlin functions that help with several past AoC problems, instructions for their AoC giveaway, and a GitHub project template to help you get started!
- ⭐⭐ (12/01/2021) Solution
- ⭐⭐ (12/02/2021) Solution
- ⭐⭐ (12/03/2021) Solution
- ⭐⭐ (12/04/2021) Solution
- ⭐⭐ (12/05/2021) Solution
- ⭐⭐ (12/06/2021) Solution
- ⭐⭐ (12/07/2021) Solution
- ⭐⭐ (12/08/2021) Solution
- ⭐⭐ (12/09/2021) Solution
- ⭐⭐ (12/10/2021) Solution
- ⭐⭐ (12/11/2021) Solution
- ⭐⭐ (12/12/2021) Solution
- ⭐⭐ (12/13/2021) Solution
- ⭐⭐ (12/14/2021) Solution
- ⭐⭐ (12/15/2021) Solution
- -
- -
...
After I finish my initial stab at a puzzle, I like to look at other #aoc-2021-in-kotlin repos for inspiration. Lots of times I see solutions that make me think: "Wow! That's cool!" This year I'll be keeping track of my Favorite Solutions from the community (with minor changes to meet this project's style).
A function that can be used on Iterable
s and Sequence
s to look at rolling windows of values. For example listOf(1, 2, 3, 4, 5).windowed(2)
, would give us [[1, 2], [2, 3], [3, 4], [4, 5]]
. You can specify custom window sizes (e.g. window size of 3 to get sub-lists of size 3), and you can specify that you're willing to accept partial windows once you get to the end of the iterable or sequence.
Pass in a filter expression as an argument to count { ... }
, saving the extra line needed by a filter { ... }
when a COUNT WHERE is needed.
Use multi-line Strings for regexes to avoid needing to escape \
s, which improves regex readability. For example, consider the following greedy whitespace regex (in Java "\\s+"
):
boardLines.take(5)
.flatMap { it.split("""\s+""".toRegex()) }
.map { it.toInt() }