diff options
author | tchojnacki <tomaszchojnacki2001@gmail.com> | 2022-08-13 12:25:41 +0200 |
---|---|---|
committer | tchojnacki <tomaszchojnacki2001@gmail.com> | 2022-08-13 12:25:41 +0200 |
commit | 992d24939100a6adb466b23449a62c36736b4249 (patch) | |
tree | 778ff441bb0a14ac64aca2d6dde67b4133e566a0 /aoc-2021-kotlin/src/Day18.kt | |
parent | 2ef3cacc7766c55f3e40803e37864acc4bd4c918 (diff) | |
download | gleam_aoc2020-992d24939100a6adb466b23449a62c36736b4249.tar.gz gleam_aoc2020-992d24939100a6adb466b23449a62c36736b4249.zip |
Finish day 20
Diffstat (limited to 'aoc-2021-kotlin/src/Day18.kt')
-rw-r--r-- | aoc-2021-kotlin/src/Day18.kt | 20 |
1 files changed, 3 insertions, 17 deletions
diff --git a/aoc-2021-kotlin/src/Day18.kt b/aoc-2021-kotlin/src/Day18.kt index 84575b7..09c688a 100644 --- a/aoc-2021-kotlin/src/Day18.kt +++ b/aoc-2021-kotlin/src/Day18.kt @@ -100,15 +100,6 @@ object Day18 { ).also { it.reduce() } } - private fun <T> combinations(items: Sequence<T>): Sequence<Pair<T, T>> = - sequence { - items.forEach { a -> - items.forEach { b -> - yield(a to b) - } - } - } - fun part1(input: List<String>): Int = input .asSequence() @@ -116,14 +107,9 @@ object Day18 { .reduce(SnailfishNum::plus) .magnitude() - fun part2(input: List<String>): Int = - combinations( - input - .asSequence() - .map(SnailfishNum::parse) - ) - .filter { it.first !== it.second } - .maxOf { (it.first + it.second).magnitude() } + fun part2(input: List<String>): Int = combinations(input.map(SnailfishNum::parse)) + .filter { it.first !== it.second } + .maxOf { (it.first + it.second).magnitude() } } fun main() { |