aboutsummaryrefslogtreecommitdiff
path: root/2021-kotlin/src/Day06.kt
diff options
context:
space:
mode:
authortchojnacki <tomaszchojnacki2001@gmail.com>2022-08-11 12:01:44 +0200
committertchojnacki <tomaszchojnacki2001@gmail.com>2022-08-11 12:01:44 +0200
commit34c2414304d59e76d52b96efe6bebebb4e75f086 (patch)
tree2b78254a2a909521993caa459b24ab68fae43324 /2021-kotlin/src/Day06.kt
parent8742021f42d2c5417abad25bfdb6d7abbf6e759e (diff)
downloadgleam_aoc2020-34c2414304d59e76d52b96efe6bebebb4e75f086.tar.gz
gleam_aoc2020-34c2414304d59e76d52b96efe6bebebb4e75f086.zip
Move year 2021 into a subfolder
Diffstat (limited to '2021-kotlin/src/Day06.kt')
-rw-r--r--2021-kotlin/src/Day06.kt38
1 files changed, 38 insertions, 0 deletions
diff --git a/2021-kotlin/src/Day06.kt b/2021-kotlin/src/Day06.kt
new file mode 100644
index 0000000..4627cca
--- /dev/null
+++ b/2021-kotlin/src/Day06.kt
@@ -0,0 +1,38 @@
+object Day06 {
+ private fun calculateFishPopulation(input: String, days: Int): Long {
+ val fishCounts =
+ input
+ .trim()
+ .split(",")
+ .map(String::toInt)
+ .groupingBy { it }
+ .eachCount()
+ .mapValues { (_, v) -> v.toLong() }
+ .toMutableMap()
+
+ repeat(days) {
+ val readyToBirth = fishCounts.getOrDefault(0, 0)
+ repeat(8) {
+ fishCounts[it] = fishCounts.getOrDefault(it + 1, 0)
+ }
+ fishCounts.merge(6, readyToBirth, Long::plus)
+ fishCounts[8] = readyToBirth
+ }
+
+ return fishCounts.values.sum()
+ }
+
+ fun part1(input: String): Int = calculateFishPopulation(input, 80).toInt()
+
+ fun part2(input: String): Long = calculateFishPopulation(input, 256)
+}
+
+fun main() {
+ val testInput = readInputAsString("Day06_test")
+ check(Day06.part1(testInput) == 5934)
+ check(Day06.part2(testInput) == 26984457539)
+
+ val input = readInputAsString("Day06")
+ println(Day06.part1(input))
+ println(Day06.part2(input))
+}