AoC/2024/src/main/kotlin/day11.kt

29 lines
799 B
Kotlin
Raw Normal View History

2024-12-11 21:01:45 +01:00
fun main() {
val input = readInputString("day11.txt").split(" ").map { it.toLong() }
2024-12-12 18:56:24 +01:00
val part1 = input.blink(25)
2024-12-11 21:01:45 +01:00
println("Part 1: $part1")
2024-12-12 18:56:24 +01:00
val part2 = input.blink(75)
2024-12-11 21:01:45 +01:00
println("Part 2: $part2")
}
2024-12-12 18:56:24 +01:00
fun List<Long>.blink(count: Int) = fold(0L) { acc, stone -> acc + blink(stone, count) }
val memo = mutableMapOf<Pair<Long, Int>, Long>()
fun blink(stone: Long, count: Int): Long = memo.getOrPut(Pair(stone, count)) {
if (count == 0) return 1
val str = "$stone"
2024-12-11 21:01:45 +01:00
val strLen = str.count()
when {
2024-12-12 18:56:24 +01:00
stone == 0L -> blink(1L, count - 1)
strLen % 2 == 0 ->
blink(str.substring(0, strLen / 2).toLong(), count - 1) +
blink(str.substring(strLen / 2).toLong(), count - 1)
else -> blink(stone * 2024, count - 1)
2024-12-11 21:01:45 +01:00
}
2024-12-12 18:56:24 +01:00
}