From d54b9f9812a3849f95f5555b8f011e599c2fd9dd Mon Sep 17 00:00:00 2001 From: Bill Ewanick Date: Sat, 21 Dec 2024 13:06:55 -0500 Subject: [PATCH] Be smarter! --- src/advent_of_code/2024/1.hs | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/src/advent_of_code/2024/1.hs b/src/advent_of_code/2024/1.hs index 3a32bc0..b9bd34f 100644 --- a/src/advent_of_code/2024/1.hs +++ b/src/advent_of_code/2024/1.hs @@ -6,8 +6,9 @@ import GHC.IO (unsafePerformIO) input :: FilePath input = "src/advent_of_code/2024/1.input" -entries :: ([Int], [Int]) -entries = unzip $ map parse' $ unsafePerformIO $ lines <$> readFile input +-- entries :: ([Int], [Int]) +-- entries = unzip $ map parse' $ unsafePerformIO $ lines <$> readFile input +entries = unsafePerformIO $ lines <$> readFile input main :: IO () main = do @@ -20,12 +21,10 @@ main = do parse' :: String -> (Int, Int) parse' str = (read l, read r) where - l = take' str - r = reverse $ take' $ reverse str - take' = takeWhile (/= ' ') + [l, r] = words str solveP1 :: ([Int], [Int]) -> Int -solveP1 (as, bs) = sum $ zipWith (\i j -> abs (i - j)) as' bs' +solveP1 (as, bs) = sum $ map abs $ zipWith subtract as' bs' where as' = sort as bs' = sort bs