diff options
Diffstat (limited to 'day11/day11.hs')
-rw-r--r-- | day11/day11.hs | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/day11/day11.hs b/day11/day11.hs new file mode 100644 index 0000000..cf1c4e0 --- /dev/null +++ b/day11/day11.hs @@ -0,0 +1,38 @@ +import Data.List + +type Stone = Int + +atoi :: String -> Stone +atoi = read + +maybeSplitDigs :: Stone -> Maybe (Stone, Stone) +maybeSplitDigs s + | even ln = Just (s `divMod` md) + | otherwise = Nothing + where + ln = ceiling $ logBase 10 $ fromIntegral s + md = 10 ^ (ln `div` 2) + +blink :: [Stone] -> [Stone] -> [Stone] +blink acc [] = reverse acc +blink acc (h:t) + | h == 0 = + blink (1:acc) t + | h == 1 = + blink (2024:acc) t + | Just (left, right) <- maybeSplitDigs h = + blink (right:left:acc) t + | otherwise = + blink (h * 2024:acc) t + +consume :: String -> [Stone] +consume = map atoi . words + +part1 :: [Stone] -> Int +part1 = length . last . take 26 . iterate (blink []) + +main = do + file <- readFile "day11.input" + let stones = consume file + putStrLn ("Part 1: " ++ (show $ part1 stones)) + --putStrLn ("Part 2: " ++ (show $ part2 mp)) |