🎄Advent of Code - Refactor Day 6 with JetBrains AI ✨
This commit is contained in:
parent
cf840f82aa
commit
b3a8f7d331
2 changed files with 12 additions and 21 deletions
|
@ -5,37 +5,28 @@ import AdventOfCode.Puzzle
|
||||||
data class Race(val raceTime: Long, val distance: Long)
|
data class Race(val raceTime: Long, val distance: Long)
|
||||||
class WaitForIt : Puzzle("2023", "6") {
|
class WaitForIt : Puzzle("2023", "6") {
|
||||||
|
|
||||||
fun getRaceTimesPart1(): List<Race> {
|
private fun getRaceTimesPart1(): List<Race> = inputData.map {
|
||||||
return inputData.map {
|
// Split on spaces, ignore first item, transform tokens to integers
|
||||||
// Split on spaces, ignore first item, transform tokens to integers
|
it.split(Regex("\\s")).drop(1).map { it.trim().toLongOrNull() }.filterNotNull()
|
||||||
it.split(Regex("\\s")).drop(1).map { it.trim().toLongOrNull() }.filterNotNull()
|
}.zipWithNext().map {
|
||||||
}.zipWithNext().map {
|
// Take the zipped lines (since we only have 2) and transform them into races.
|
||||||
// Take the zipped lines (since we only have 2) and transform them into races.
|
it.first.mapIndexed { index, i -> Race(i, it.second[index]) }
|
||||||
it.first.mapIndexed { index, i -> Race(i, it.second[index]) }
|
}.flatten().also {
|
||||||
}.flatten().also {
|
println("The input is $it")
|
||||||
println("The input is $it")
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun partOne() {
|
override fun partOne() {
|
||||||
getRaceTimesPart1().map {
|
getRaceTimesPart1().map {
|
||||||
// here we transform a race into a list of all the possible combinations that we can have
|
// here we transform a race into a list of all the possible combinations that we can have
|
||||||
(1..<it.raceTime).map { time -> Race((it.raceTime - time) * time, it.distance) }
|
(1..<it.raceTime).count { time -> (it.raceTime - time) * time > it.distance }
|
||||||
}.parallelStream().map {
|
}.reduce { acc, i -> acc * i }.also {
|
||||||
// Here we filter out the losing races
|
|
||||||
it.filter { it.raceTime > it.distance }.count()
|
|
||||||
}.reduce { acc, i -> acc * i }.get().also {
|
|
||||||
println("The number of ways the record was beaten $it.")
|
println("The number of ways the record was beaten $it.")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
override fun partTwo() {
|
override fun partTwo() {
|
||||||
listOf(Race(49787980, 298118510661181)).map {
|
listOf(Race(49787980, 298118510661181)).map {
|
||||||
// here we transform a race into a list of all the possible combinations that we can have
|
(1..<it.raceTime).count { time -> (it.raceTime - time) * time > it.distance }
|
||||||
(1..<it.raceTime).map { time -> Race((it.raceTime - time) * time, it.distance) }
|
|
||||||
}.map {
|
|
||||||
// Here we filter out the losing races
|
|
||||||
it.parallelStream().filter { it.raceTime > it.distance }.count()
|
|
||||||
}.reduce { acc, i -> acc * i }.also {
|
}.reduce { acc, i -> acc * i }.also {
|
||||||
println("The number of ways the record was beaten $it.")
|
println("The number of ways the record was beaten $it.")
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,7 +4,7 @@ import kotlin.system.measureTimeMillis
|
||||||
fun main(args: Array<String>) {
|
fun main(args: Array<String>) {
|
||||||
val t = WaitForIt()
|
val t = WaitForIt()
|
||||||
val time = measureTimeMillis {
|
val time = measureTimeMillis {
|
||||||
// t.partOne()
|
t.partOne()
|
||||||
t.partTwo()
|
t.partTwo()
|
||||||
}
|
}
|
||||||
println("Took $time ms.")
|
println("Took $time ms.")
|
||||||
|
|
Loading…
Reference in a new issue