aoc/app/3.hs

33 lines
893 B
Haskell
Raw Normal View History

2024-12-02 10:51:49 +00:00
{-# LANGUAGE LambdaCase #-}
module Main where
2024-12-03 08:06:27 +00:00
import Text.Regex.TDFA
import Data.List.Split
2024-12-02 10:51:49 +00:00
2024-12-03 08:06:27 +00:00
e :: [String] -> [(Int,Int)]
e = ((\case
2024-12-03 11:52:47 +00:00
[a,b] -> (read a, read b)
err -> error $ "Parsing failed on: " ++ show err
) . splitWhen (== ',') . init . drop 4 <$>)
2024-12-02 10:51:49 +00:00
2024-12-03 08:06:27 +00:00
parse1 :: String -> [(Int,Int)]
parse1 = e . getAllTextMatches . (=~ "mul\\([[:digit:]]+,[[:digit:]]+\\)")
2024-12-02 10:51:49 +00:00
2024-12-03 08:06:27 +00:00
parse2 :: String -> [(Int,Int)]
parse2 =
let h [] = []
h a = let (t,t') = span (/= "don't()") a in t ++ g t'
g [] = []
g a = h . dropWhile (== "do()") $ dropWhile (/= "do()") a in
e . filter (/= "do()") . h .
getAllTextMatches . (=~ "mul\\([[:digit:]]+,[[:digit:]]+\\)|do\\(\\)|don't\\(\\)")
solve :: [(Int,Int)] -> Int
solve = foldr ((+) . uncurry (*)) 0
2024-12-02 10:51:49 +00:00
main :: IO ()
2024-12-03 08:06:27 +00:00
main = readFile "inputs/3" >>= \i ->
print (solve $ parse1 i) >>
print (solve $ parse2 i)