From c37a69ec2c26ad025956bb14a4c88c15e295b36d Mon Sep 17 00:00:00 2001 From: tchojnacki Date: Tue, 14 Dec 2021 18:43:35 +0100 Subject: Finish day 14 --- src/Day14.kt | 45 +++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 src/Day14.kt (limited to 'src') diff --git a/src/Day14.kt b/src/Day14.kt new file mode 100644 index 0000000..fb6a43e --- /dev/null +++ b/src/Day14.kt @@ -0,0 +1,45 @@ +fun getPolymerLetterCounts(input: List, iterations: Int): Long { + val template = input.first() + val rules = input.drop(2).associate { + val (pattern, replacement) = it.split(" -> ") + (pattern[0] to pattern[1]) to replacement.first() + } + + var pairCounts = template + .zipWithNext() + .groupingBy { it } + .eachCount() + .mapValues { (_, v) -> v.toLong() } + + repeat(iterations) { + val newCounts = mutableMapOf, Long>() + + pairCounts.forEach { (pair, count) -> + newCounts.merge(rules[pair]!! to pair.second, count, Long::plus) + newCounts.merge(pair.first to rules[pair]!!, count, Long::plus) + } + + pairCounts = newCounts + } + + val letterCounts = mutableMapOf() + pairCounts.forEach { (pair, count) -> letterCounts.merge(pair.second, count, Long::plus) } + letterCounts.merge(template.first(), 1, Long::plus) + + return letterCounts.values.let { it.maxOrNull()!! - it.minOrNull()!! } +} + +fun main() { + fun part1(input: List): Long = getPolymerLetterCounts(input, 10) + + fun part2(input: List): Long = getPolymerLetterCounts(input, 40) + + + val testInput = readInputAsLines("Day14_test") + check(part1(testInput) == 1588L) + check(part2(testInput) == 2188189693529L) + + val input = readInputAsLines("Day14") + println(part1(input)) + println(part2(input)) +} -- cgit v1.2.3