adventofcode-2020/day9/main.hs

76 lines
2.2 KiB
Haskell
Raw Normal View History

2020-12-10 13:30:34 +02:00
#! /usr/bin/env -S"ANSWER=42" nix-shell
#! nix-shell -p ghcid
2020-12-10 14:26:48 +02:00
#! nix-shell -p "haskellPackages.ghcWithPackages (p: with p; [pretty-simple containers])"
2020-12-10 13:30:34 +02:00
#! nix-shell -i "ghcid -c 'ghci' -T main"
{-# OPTIONS_GHC -Wall -Wincomplete-uni-patterns #-}
{-# OPTIONS_GHC -Wno-unused-top-binds -Wno-unused-imports #-}
{-# LANGUAGE OverloadedStrings #-}
import Data.IntMap.Strict (IntMap)
2020-12-10 14:26:48 +02:00
import Data.IntSet (IntSet)
import Data.List (inits, tails, sortOn)
import Data.Monoid
2020-12-10 13:30:34 +02:00
import Debug.Trace (trace)
import Text.Pretty.Simple
import qualified Data.IntMap.Strict as M
2020-12-10 14:26:48 +02:00
import qualified Data.IntSet as S
2020-12-10 13:30:34 +02:00
exampleData :: [Int]
exampleData = [ 35,20,15,25,47,40,62,55,65,95,102,117,150
, 182,127,219,299,277,309,576 ];
2020-12-10 14:26:48 +02:00
pairSums :: [Int] -> IntSet
pairSums xs = S.fromList $ do
i1 <- xs
i2 <- xs
pure (i1 + i2)
isSumOfPreamble :: Int -> [Int] -> Bool
isSumOfPreamble size xs = go tx
where
go (x:_) = x `S.member` (pairSums preamble)
go ([]) = False
(preamble, tx) = splitAt size xs
solvePart1 :: Int -> [Int] -> (Int,Bool)
solvePart1 size message =
head $ dropWhile (snd) $
map go ( takeWhile ((> size) . length) $ tails message )
where
go xs = (head $ drop size xs,isSumOfPreamble size xs)
--------------------------------------------------------------------------------
sortedContiguousSubLists :: [Int] -> [[Int]]
sortedContiguousSubLists =
dropWhile (== []) . sortOn length . concat . fmap inits . tails
listSums :: [[Int]] -> IntMap [Int]
listSums xss = M.fromList $ do
xs <- xss
pure $ (getSum $ foldMap Sum xs, xs)
solvePart2 :: Int -> [Int] -> Int
solvePart2 target message = (\x -> minimum x + maximum x) $ bigMap M.! target
where
bigMap = listSums $ sortedContiguousSubLists message
2020-12-10 13:30:34 +02:00
main :: IO ()
main = do
putStrLn "Test"
2020-12-10 14:26:48 +02:00
print exampleData
print $ 1 `S.member` (pairSums [])
print $ pairSums exampleData
2020-12-10 13:30:34 +02:00
putStrLn "Day 9 - Part 1"
2020-12-10 14:26:48 +02:00
print $ solvePart1 5 exampleData
input <- lines <$> readFile "day9/input"
print $ solvePart1 25 $ map read input
putStrLn "Test"
print $ take 10 $ drop 20 $ sortedContiguousSubLists exampleData
putStrLn "Day 9 - Part 2"
print $ solvePart2 127 exampleData
print $ solvePart2 3199139634 $ map read input