From 384aac090c747dbbbaadaff668050dc43ea4b706 Mon Sep 17 00:00:00 2001 From: Juris Date: Tue, 5 Dec 2023 22:16:43 +0200 Subject: [PATCH] 2023, Day 5 - refactoring --- .../jurisk/adventofcode/y2023/Advent05.scala | 19 +++++++------------ 1 file changed, 7 insertions(+), 12 deletions(-) diff --git a/scala2/src/main/scala/jurisk/adventofcode/y2023/Advent05.scala b/scala2/src/main/scala/jurisk/adventofcode/y2023/Advent05.scala index c0b954d9..e9dbc7ec 100644 --- a/scala2/src/main/scala/jurisk/adventofcode/y2023/Advent05.scala +++ b/scala2/src/main/scala/jurisk/adventofcode/y2023/Advent05.scala @@ -32,18 +32,15 @@ object Advent05 extends IOApp.Simple { def potentialIntervals( intervalSet: NonOverlappingDiscreteIntervalSet[Long] ): NonOverlappingDiscreteIntervalSet[Long] = { - var convertedAll = NonOverlappingDiscreteIntervalSet.empty[Long] - var coveredAll = NonOverlappingDiscreteIntervalSet.empty[Long] - - converters.foreach { converter => - val conversionResult = converter.potentialIntervals(intervalSet) - - convertedAll = convertedAll union conversionResult.converted - coveredAll = coveredAll union conversionResult.covered + val results = converters.foldLeft(ConversionResult.empty) { + case (acc, converter) => + acc union converter.potentialIntervals(intervalSet) } - val straightThrough = intervalSet subtract coveredAll - straightThrough union convertedAll + // The converters did not pick up some intervals, they stay as they were + val straightThrough = intervalSet subtract results.covered + + straightThrough union results.converted } } @@ -72,8 +69,6 @@ object Advent05 extends IOApp.Simple { covered: NonOverlappingDiscreteIntervalSet[Long], converted: NonOverlappingDiscreteIntervalSet[Long], ) { - assert(covered.size == converted.size) - def union(other: ConversionResult): ConversionResult = ConversionResult( uncovered = uncovered union other.uncovered,