2024-12-03 14:08:41 +01:00
|
|
|
module Main where
|
|
|
|
|
|
|
|
import System.Environment (getArgs)
|
|
|
|
|
|
|
|
import Data.List (sort)
|
2024-12-03 17:39:36 +01:00
|
|
|
import Data.Function (on)
|
2024-12-03 14:08:41 +01:00
|
|
|
|
2024-12-03 15:02:07 +01:00
|
|
|
import Text.Parsec (parse, many, char, endBy)
|
|
|
|
import Text.ParserCombinators.Parsec (GenParser)
|
|
|
|
import Text.ParserCombinators.Parsec.Number (decimal)
|
2024-12-03 14:08:41 +01:00
|
|
|
|
2024-12-03 15:02:07 +01:00
|
|
|
line :: GenParser Char st (Int, Int)
|
|
|
|
line = decimal >>= \l -> many (char ' ') >> decimal >>= \r -> return (l, r)
|
2024-12-03 14:08:41 +01:00
|
|
|
|
2024-12-03 15:02:07 +01:00
|
|
|
locationIDs :: GenParser Char st [(Int, Int)]
|
|
|
|
locationIDs = endBy line (char '\n')
|
2024-12-03 14:08:41 +01:00
|
|
|
|
2024-12-03 17:39:36 +01:00
|
|
|
part1 :: [Int] -> [Int] -> Int
|
|
|
|
part1 l r = sum (zipWith (curry (abs . uncurry (-))) l r)
|
|
|
|
|
|
|
|
part2 :: [Int] -> [Int] -> Int
|
|
|
|
part2 l r = (sum . map (\x -> sum ((map (const x) . filter (==x)) r))) l
|
2024-12-03 14:08:41 +01:00
|
|
|
|
|
|
|
main :: IO ()
|
|
|
|
main = do
|
|
|
|
args <- getArgs
|
|
|
|
(fp:_) <- return args
|
2024-12-03 15:02:07 +01:00
|
|
|
content <- readFile fp
|
|
|
|
case parse locationIDs fp content of
|
|
|
|
Left e -> putStrLn ("Input file is incorrectly formatted : " ++ show e)
|
2024-12-03 17:39:36 +01:00
|
|
|
Right ids -> do
|
|
|
|
let (ls, rs) = uncurry ((,) `on` sort) (unzip ids)
|
|
|
|
putStrLn ("Solution (Part 1) : " ++ show (part1 ls rs))
|
|
|
|
putStrLn ("Solution (Part 2) : " ++ show (part2 ls rs))
|