Created
December 2, 2019 16:23
-
-
Save jonathan-ostrander/35b47deeafb22b564d639827cebae0de to your computer and use it in GitHub Desktop.
AoC Day 2
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
package aoc | |
object ProblemTwo extends App { | |
println( | |
(Vector(Vector(12, 2)) ++ ((0 to 100) ++ (0 to 100)).combinations(2)).map(v => | |
( | |
v, | |
Stream.from(0, 4).scanLeft( | |
( | |
scala.io.Source.fromFile("inputs/2.txt") | |
.getLines | |
.next | |
.split(",") | |
.map(_.toInt) | |
.zipWithIndex | |
.map(_.swap) | |
.toMap ++ Map(1 -> v(0), 2 -> v(1)), | |
true | |
) | |
)((a, i) => | |
if (a._1(i) == 99) a._1 -> false | |
else if (a._1(i) == 1) a._1 ++ Map(a._1(i + 3) -> (a._1(a._1(i + 1)) + a._1(a._1(i + 2)))) -> true | |
else if (a._1(i) == 2) a._1 ++ Map(a._1(i + 3) -> (a._1(a._1(i + 1)) * a._1(a._1(i + 2)))) -> true | |
else sys.error("bad input") | |
) | |
.dropWhile(_._2) | |
.head | |
._1(0) | |
) | |
) | |
.zipWithIndex | |
.flatMap(t => | |
if (t._2 == 0) Some(s"Part 1: ${t._1._2}") | |
else if (t._1._2 == 19690720) Some(s"Part 2: ${100 * t._1._1(0) + t._1._1(1)}") | |
else None | |
) | |
.take(2) | |
.mkString("\n") | |
) | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment