AoC/2023/day09/day09.hs

18 lines
359 B
Haskell
Raw Normal View History

2023-12-09 17:05:01 +01:00
import Control.Arrow
main :: IO ()
main = do
input <- parse <$> readFile "input"
print $ day09 input
parse :: String -> [[Int]]
parse = map (map read . words) . lines
day09 :: [[Int]] -> (Int, Int)
day09 =
(sum *** sum) .
unzip .
map
((sum . map last &&& foldr1 (-) . map head) .
2023-12-09 17:05:01 +01:00
takeWhile (not . null) . iterate (zipWith (-) =<< tail))