From 59f1776dd7a967114773ed87b039871920cfae18 Mon Sep 17 00:00:00 2001 From: Tom Smeding Date: Mon, 9 Dec 2024 20:53:15 +0100 Subject: 8 --- 2024/8.hs | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) create mode 100644 2024/8.hs (limited to '2024/8.hs') diff --git a/2024/8.hs b/2024/8.hs new file mode 100644 index 0000000..a7b9fb8 --- /dev/null +++ b/2024/8.hs @@ -0,0 +1,21 @@ +import qualified Data.Map.Strict as Map +import qualified Data.Set as Set + +main :: IO () +main = do + input <- lines <$> getContents + let h = length input + let w = length (head input) + let inBounds (x, y) = 0 <= x && x < w && 0 <= y && y < h + let indexed2 = zipWith (\y -> zipWith (\x -> ((x,y),)) [0::Int ..]) [0::Int ..] + let pts = Map.fromListWith (++) . map (\(p, c) -> (c, [p])) . filter ((/= '.') . snd) $ concat (indexed2 input) + let groups = map snd (Map.assocs pts) + let (x,y) .+ (dx,dy) = (x+dx, y+dy) + let (x,y) .- (dx,dy) = (x-dx, y-dy) + let antinodes1 p q = let d = q .- p in filter inBounds [p .- d, q .+ d] + let antinodes2 p q = let d = q .- p + in takeWhile inBounds (iterate (.- d) p) ++ takeWhile inBounds (iterate (.+ d) q) + let pairs [] = [] + pairs (x:xs) = map (x,) xs ++ pairs xs + print $ Set.size $ Set.fromList $ concatMap (concatMap (uncurry antinodes1) . pairs) groups + print $ Set.size $ Set.fromList $ concatMap (concatMap (uncurry antinodes2) . pairs) groups -- cgit v1.2.3-70-g09d2