Day 8
This commit is contained in:
77
src/main/kotlin/com/basdado/adventofcode/Day8.kt
Normal file
77
src/main/kotlin/com/basdado/adventofcode/Day8.kt
Normal file
@@ -0,0 +1,77 @@
|
||||
package com.basdado.adventofcode
|
||||
|
||||
import java.util.stream.Stream
|
||||
|
||||
fun main() {
|
||||
val day = Day8()
|
||||
day.puzzle1()
|
||||
day.puzzle2()
|
||||
}
|
||||
|
||||
class Day8 {
|
||||
|
||||
fun puzzle1() {
|
||||
val root = parseInput()
|
||||
println(flatMap(root) { it.metadata.stream() }.mapToInt{ it }.sum())
|
||||
}
|
||||
|
||||
fun puzzle2() {
|
||||
val root = parseInput()
|
||||
println(findValue(root))
|
||||
}
|
||||
|
||||
private fun parseInput(): Node {
|
||||
val input = lines("/day/8/input.txt")
|
||||
.findFirst().get()
|
||||
.split(Regex("""\s+"""))
|
||||
.map { it.toInt() }
|
||||
.toIntArray()
|
||||
|
||||
return parse(input)
|
||||
}
|
||||
|
||||
fun parse(arr: IntArray, startIndex: Int = 0): Node {
|
||||
|
||||
var index = startIndex;
|
||||
val nodeCount = arr[index++]
|
||||
val metadataCount = arr[index++]
|
||||
|
||||
var children = mutableListOf<Node>()
|
||||
for (i in 0 until nodeCount) {
|
||||
val newChild = parse(arr, index)
|
||||
index = newChild.endIndex
|
||||
children.add(newChild)
|
||||
}
|
||||
val metadata = arr.copyOfRange(index, index + metadataCount).toList()
|
||||
index += metadataCount
|
||||
|
||||
return Node(children, metadata, index)
|
||||
}
|
||||
|
||||
fun <T> flatMap(node: Node, mapping: Function1<Node, Stream<T>>): Stream<T> {
|
||||
|
||||
var res = mapping.invoke(node)
|
||||
for (child in node.children) {
|
||||
res = Stream.concat(res, flatMap(child, mapping))
|
||||
}
|
||||
return res
|
||||
}
|
||||
|
||||
fun findValue(node: Node): Int {
|
||||
|
||||
if (node.children.isEmpty()) {
|
||||
return node.metadata.toIntArray().sum()
|
||||
} else {
|
||||
var sum = 0
|
||||
for (index in node.metadata) {
|
||||
|
||||
if (index > 0 && index <= node.children.size) {
|
||||
sum += findValue(node.children[index - 1])
|
||||
}
|
||||
}
|
||||
return sum
|
||||
}
|
||||
}
|
||||
|
||||
data class Node (val children: List<Node>, val metadata: List<Int>, val endIndex: Int)
|
||||
}
|
||||
1
src/main/resources/day/8/input.txt
Normal file
1
src/main/resources/day/8/input.txt
Normal file
File diff suppressed because one or more lines are too long
Reference in New Issue
Block a user