aoc/app/9.hs

57 lines
1.6 KiB
Haskell
Raw Normal View History

2024-12-02 10:51:49 +00:00
{-# LANGUAGE LambdaCase #-}
module Main where
import Data.Functor
2024-12-09 09:57:31 +00:00
import Data.List.Extra hiding (split)
2024-12-02 10:51:49 +00:00
2024-12-09 09:26:30 +00:00
data where
None ::
Num :: Int ->
deriving Eq
2024-12-02 10:51:49 +00:00
2024-12-09 09:26:30 +00:00
instance Show where
show None = show '.'
show (Num n) = show n
2024-12-02 10:51:49 +00:00
2024-12-09 09:26:30 +00:00
parse :: String -> []
parse s = zip [0..] (trim s) >>= \(i,a) -> replicate (read [a]) (if even i then Num (i `div` 2) else None)
sort1 :: [] -> []
sort1 s
| None `notElem` s = s
| otherwise = case last s of
None -> sort1 $ init s
n -> sort1 $ takeWhile (/= None) s ++ [n] ++ drop 1 (dropWhile (/= None) (init s))
2024-12-09 09:57:31 +00:00
chunks :: [] -> [[]]
chunks =
init . foldr (\a (x:xs) -> if a `elem` x then (a:x):xs else [a]:x:xs) [[]]
fit :: [[]] -> [] -> []
fit s t = let (p,a) = break (elem None) s
(n,a') = span (elem None) a in
if null n then concat s ++ t else
2024-12-09 12:06:59 +00:00
concat p ++ if length (head n) >= length t then t ++ replicate (length (head n) - length t) None ++ concat a' ++ replicate (length t) None else concat n ++ fit a' t
2024-12-09 09:57:31 +00:00
2024-12-09 09:26:30 +00:00
sort2 :: [] -> []
2024-12-09 12:06:59 +00:00
sort2 s = let c = chunks s
fitted = fit (init c) (last c)
c' = chunks fitted
in
case length c' of
0 -> concat c'
1 -> concat c'
2 -> concat c'
_ -> (sort2 . concat $ init c') ++ last c'
2024-12-09 09:26:30 +00:00
solve :: ([] -> []) -> [] -> Int
2024-12-09 09:57:31 +00:00
solve f s = let fixed = (\case
Num n -> n
None -> 0) <$> f s in
2024-12-09 09:26:30 +00:00
sum $ zipWith (*) fixed [0..]
2024-12-02 10:51:49 +00:00
main :: IO ()
2024-12-09 12:06:59 +00:00
main = readFile "inputs/9" <&> parse >>= \i ->
2024-12-09 09:26:30 +00:00
print (solve sort1 i) >>
print (solve sort2 i)