Day 10 cleanup

This commit is contained in:
Paul-Henri Froidmont 2022-12-10 07:39:52 +01:00
parent c3919a1e57
commit 4b2867b1c7
Signed by: phfroidmont
GPG key ID: BE948AFD7E7873BE

View file

@ -6,44 +6,25 @@ object Day10 extends App:
.fromURL(getClass.getResource("day10Input.txt")) .fromURL(getClass.getResource("day10Input.txt"))
.mkString .mkString
.split('\n') .split('\n')
.toList .map(_.split(" "))
.map(_.split(" ")).map {
case Array(inst, value) => (inst, value.toInt)
case Array(inst) => (inst, 0)
}
.flatMap { .flatMap {
case inst @ ("noop", _) => List(inst) case Array("addx", value) => List(0, value.toInt)
case inst @ ("addx", _) => List(("noop", 0), inst) case Array("noop") => List(0)
} }
val execution = input.scanLeft((1, 1)) { val registerStates = input.scan(1)(_ + _)
case ((register, cycle), ("noop", _)) => (register, cycle + 1)
case ((register, cycle), ("addx", value)) => (register + value, cycle + 1)
case ((register, cycle), _) => (register, cycle + 1)
}
val interestingSignals = val part1 = (20 to 220 by 40).map(s => registerStates(s - 1) * s).sum
(20 to execution.last._2).filter(cycle => cycle == 20 || (cycle + 20) % 40 == 0)
val part1 = execution
.filter(state => interestingSignals.contains(state._2))
.map(_._1)
.zip(interestingSignals)
.map(_ * _)
.sum
println(s"Part 1: $part1") println(s"Part 1: $part1")
def renderRow(rowExecution: List[(Int, Int)]): String = val part2 = registerStates
rowExecution.foldLeft("") { case (line, (register, cycle)) =>
val spritePosition = register - 1 to register + 1
if spritePosition.contains((cycle - 1) % 40) then line + "#"
else line + "."
}
val part2 = execution
.grouped(40) .grouped(40)
.map(renderRow) .map(
_.zip(0 to 39)
.map((reg, cycle) => Math.abs(reg - cycle) <= 1)
.map(if _ then "#" else ".")
.mkString
)
.mkString("\n") .mkString("\n")
println(s"Part 2:") println("Part 2:")
println(part2) println(part2)
end Day10