{-# Language QuasiQuotes #-}
module Main where
import Advent (format, partialSums)
import Data.Foldable (traverse_)
import Data.List (elemIndex)
main :: IO ()
IO ()
main =
do inp <- [format|2015 1 %s%n|]
let xs = (Char -> Int) -> [Char] -> [Int]
forall a b. (a -> b) -> [a] -> [b]
map Char -> Int
interpret [Char]
inp
print (sum xs)
traverse_ print (part2 xs)
interpret :: Char -> Int
interpret :: Char -> Int
interpret Char
'(' = Int
1
interpret Char
')' = -Int
1
interpret Char
x = [Char] -> Int
forall a. HasCallStack => [Char] -> a
error ([Char]
"No interpretation for: " [Char] -> [Char] -> [Char]
forall a. [a] -> [a] -> [a]
++ [Char
x])
part2 :: [Int] -> Maybe Int
part2 :: [Int] -> Maybe Int
part2 = Int -> [Int] -> Maybe Int
forall a. Eq a => a -> [a] -> Maybe Int
elemIndex (-Int
1) ([Int] -> Maybe Int) -> ([Int] -> [Int]) -> [Int] -> Maybe Int
forall b c a. (b -> c) -> (a -> b) -> a -> c
. [Int] -> [Int]
forall a. Num a => [a] -> [a]
partialSums