feat(day2): Follow the same logic for part 2
This commit is contained in:
parent
cb83e4247d
commit
45c9a200e2
35
day2/Main.hs
35
day2/Main.hs
|
@ -23,19 +23,28 @@ pairUp :: [a] -> [(a, a)]
|
||||||
pairUp (a:b:tl) = (a, b) : pairUp (b:tl)
|
pairUp (a:b:tl) = (a, b) : pairUp (b:tl)
|
||||||
pairUp _ = []
|
pairUp _ = []
|
||||||
|
|
||||||
allIncOrDec :: Report -> Bool
|
allIncOrDec :: Bool -> Report -> Bool
|
||||||
allIncOrDec (a:b:tl)
|
allIncOrDec dampened (a:b:tl) = if a /= b
|
||||||
| a /= b = all (uncurry (if a < b then (<) else (>))) $ pairUp $ b:tl
|
then (if dampened then (>=) 0 else (==) 0)
|
||||||
| otherwise = False
|
$ length
|
||||||
allIncOrDec _ = True
|
$ filter (not . uncurry (if a < b then (<) else (>)))
|
||||||
|
$ pairUp
|
||||||
|
$ b:tl
|
||||||
|
else dampened && allIncOrDec False (b:tl)
|
||||||
|
allIncOrDec _ _ = True
|
||||||
|
|
||||||
notTooDifferent :: Report -> Bool
|
notTooDifferent :: Bool -> Report -> Bool
|
||||||
notTooDifferent (a:b:tl) = let dif = abs (a - b)
|
notTooDifferent dampened (a:b:tl) =
|
||||||
in (1 <= dif) && (dif <= 3) && notTooDifferent (b:tl)
|
let dif = abs (a - b)
|
||||||
notTooDifferent _ = True
|
in if (1 <= dif) && (dif <= 3)
|
||||||
|
then notTooDifferent dampened (b:tl)
|
||||||
|
else dampened && notTooDifferent False (b:tl)
|
||||||
|
notTooDifferent _ _ = True
|
||||||
|
|
||||||
part1 :: [Report] -> Int
|
solve :: Bool -> [Report] -> Int
|
||||||
part1 = length . filter allIncOrDec . filter notTooDifferent
|
solve dampened = length
|
||||||
|
. filter (allIncOrDec dampened)
|
||||||
|
. filter (notTooDifferent dampened)
|
||||||
|
|
||||||
main :: IO ()
|
main :: IO ()
|
||||||
main = do
|
main = do
|
||||||
|
@ -45,5 +54,5 @@ main = do
|
||||||
case parse reports fp content of
|
case parse reports fp content of
|
||||||
Left e -> putStrLn ("Input file is incorrectly formatted : " ++ show e)
|
Left e -> putStrLn ("Input file is incorrectly formatted : " ++ show e)
|
||||||
Right r -> do
|
Right r -> do
|
||||||
putStrLn ("Solution (Part 1) : " ++ show (part1 r))
|
putStrLn ("Solution (Part 1) : " ++ show (solve False r))
|
||||||
-- putStrLn ("Solution (Part 2) : " ++ show (part2 r))
|
putStrLn ("Solution (Part 2) : " ++ show (solve True r))
|
||||||
|
|
Loading…
Reference in a new issue