advent-of-code/2019/Scala/day12/Day12.scala
2019-12-12 07:31:26 +01:00

69 lines
2.3 KiB
Scala

package day12
class Day12 {
def step(array: Array[Moon], n: Int): Unit = {
for (_ <- 0 until n) {
for (i <- array.indices; j <- array.indices) {
array(i).changeVelBy(array(j))
}
for (i <- array.indices) {
array(i).physStep()
}
}
}
def print(array: Array[Moon]): Unit = {
for (i <- array.indices) {
array(i).print()
}
}
def solveP1(): Int = {
val array: Array[Moon] = Array(new Moon(-16, 15, -9), new Moon(-14, 5, 4), new Moon(2, 0, 6), new Moon(-3, 18, 9))
step(array, 1000)
array.foldLeft (0) {(a, x) => a + x.energy}
}
def solveP2(): Long = {
val array1: Array[Moon] = Array(new Moon(-16, 15, -9), new Moon(-14, 5, 4), new Moon(2, 0, 6), new Moon(-3, 18, 9))
val array2: Array[Moon] = Array(new Moon(-16, 15, -9), new Moon(-14, 5, 4), new Moon(2, 0, 6), new Moon(-3, 18, 9))
val array3: Array[Moon] = Array(new Moon(-16, 15, -9), new Moon(-14, 5, 4), new Moon(2, 0, 6), new Moon(-3, 18, 9))
@scala.annotation.tailrec
def findFirstXRepeat(array: Array[Moon], n: Int = 1): Int = {
step(array, 1)
if (array(0).posX == -16 && array(1).posX == -14 && array(2).posX == 2 && array(3).posX == -3) n+1 // n+1 because we're looking for kinetic E=0
else findFirstXRepeat(array, n+1)
}
@scala.annotation.tailrec
def findFirstYRepeat(array: Array[Moon], n: Int = 1): Int = {
step(array, 1)
if (array(0).posY == 15 && array(1).posY == 5 && array(2).posY == 0 && array(3).posY == 18) n+1 // n+1 because we're looking for kinetic E=0
else findFirstYRepeat(array, n+1)
}
@scala.annotation.tailrec
def findFirstZRepeat(array: Array[Moon], n: Int = 1): Int = {
step(array, 1)
if (array(0).posZ == -9 && array(1).posZ == 4 && array(2).posZ == 6 && array(3).posZ == 9) n+1 // n+1 because we're looking for kinetic E=0
else findFirstZRepeat(array, n+1)
}
@scala.annotation.tailrec
def GCD(a: Long, b: Long): Long = if (b == 0) a.abs else GCD(b, a % b)
def LCM(a: Long, b: Long): Long = (a * b).abs / GCD(a, b)
val repX = findFirstXRepeat(array1)
val repY = findFirstYRepeat(array2)
val repZ = findFirstZRepeat(array3)
LCM(repZ, LCM(repX, repY))
}
}