aboutsummaryrefslogtreecommitdiff
path: root/aoc-2021-kotlin/src/Day07.kt
diff options
context:
space:
mode:
authortchojnacki <tomaszchojnacki2001@gmail.com>2022-08-11 19:24:23 +0200
committertchojnacki <tomaszchojnacki2001@gmail.com>2022-08-11 19:24:23 +0200
commit0f1e145b80813ae2331b7dac5ace0c589654ad2a (patch)
tree25483b8239436dd5aed2fee8811caf0ba893c0bb /aoc-2021-kotlin/src/Day07.kt
parent85fb0396bed6a2129b12392941103924b1ab55be (diff)
downloadgleam_aoc2020-0f1e145b80813ae2331b7dac5ace0c589654ad2a.tar.gz
gleam_aoc2020-0f1e145b80813ae2331b7dac5ace0c589654ad2a.zip
Move subproject to avoid IntelliJ module name issues
Diffstat (limited to 'aoc-2021-kotlin/src/Day07.kt')
-rw-r--r--aoc-2021-kotlin/src/Day07.kt27
1 files changed, 27 insertions, 0 deletions
diff --git a/aoc-2021-kotlin/src/Day07.kt b/aoc-2021-kotlin/src/Day07.kt
new file mode 100644
index 0000000..9c1b79f
--- /dev/null
+++ b/aoc-2021-kotlin/src/Day07.kt
@@ -0,0 +1,27 @@
+import kotlin.math.absoluteValue
+
+object Day07 {
+ fun part1(input: String): Int {
+ val numbers = input.trim().split(",").map(String::toInt)
+ val range = numbers.minOrNull()!!..numbers.maxOrNull()!!
+
+ return range.minOf { n -> numbers.sumOf { (it - n).absoluteValue } }
+ }
+
+ fun part2(input: String): Int {
+ val numbers = input.trim().split(",").map(String::toInt)
+ val range = numbers.minOrNull()!!..numbers.maxOrNull()!!
+
+ return range.minOf { n -> numbers.map { (it - n).absoluteValue }.sumOf { (it * (it + 1)) / 2 } }
+ }
+}
+
+fun main() {
+ val testInput = readInputAsString("Day07_test")
+ check(Day07.part1(testInput) == 37)
+ check(Day07.part2(testInput) == 168)
+
+ val input = readInputAsString("Day07")
+ println(Day07.part1(input))
+ println(Day07.part2(input))
+}