{-# Language QuasiQuotes, BlockArguments, LambdaCase #-}
module Main where
import Advent.Format (format)
main :: IO ()
IO ()
main =
do input <- [format|2015 16 (Sue %d: (%s: %d)&(, )%n)*|]
print [i | (i, props) <- input, matchesClues1 props]
print [i | (i, props) <- input, matchesClues2 props]
matchesClues1 :: [(String,Int)] -> Bool
matchesClues1 :: [([Char], Int)] -> Bool
matchesClues1 = ([Char] -> Int -> Int -> Bool) -> [([Char], Int)] -> Bool
matcher ((Int -> Int -> Bool) -> [Char] -> Int -> Int -> Bool
forall a b. a -> b -> a
const Int -> Int -> Bool
forall a. Eq a => a -> a -> Bool
(==))
matchesClues2 :: [(String,Int)] -> Bool
matchesClues2 :: [([Char], Int)] -> Bool
matchesClues2 =
([Char] -> Int -> Int -> Bool) -> [([Char], Int)] -> Bool
matcher \case
[Char]
"cats" -> Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
(<)
[Char]
"trees" -> Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
(<)
[Char]
"pomeranians" -> Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
(>)
[Char]
"goldfish" -> Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
(>)
[Char]
_ -> Int -> Int -> Bool
forall a. Eq a => a -> a -> Bool
(==)
matcher ::
(String -> Int -> Int -> Bool) ->
[(String,Int)] ->
Bool
matcher :: ([Char] -> Int -> Int -> Bool) -> [([Char], Int)] -> Bool
matcher [Char] -> Int -> Int -> Bool
match = (([Char], Int) -> Bool) -> [([Char], Int)] -> Bool
forall (t :: * -> *) a. Foldable t => (a -> Bool) -> t a -> Bool
all \([Char]
prop, Int
memory) ->
[Char] -> Int -> Int -> Bool
match [Char]
prop ([Char] -> Int
clues [Char]
prop) Int
memory
clues :: String -> Int
clues :: [Char] -> Int
clues [Char]
"children" = Int
3
clues [Char]
"cats" = Int
7
clues [Char]
"samoyeds" = Int
2
clues [Char]
"pomeranians" = Int
3
clues [Char]
"akitas" = Int
0
clues [Char]
"vizslas" = Int
0
clues [Char]
"goldfish" = Int
5
clues [Char]
"trees" = Int
3
clues [Char]
"cars" = Int
2
clues [Char]
"perfumes" = Int
1