aoc18/2/2.hs
2018-12-02 18:54:51 +05:30

14 lines
469 B
Haskell

module Main where
import Data.List (group, sort)
main = do
ids <- lines <$> getContents
print (length (repeatCounts 2 ids) * length (repeatCounts 3 ids))
let diff = head [ diff | x <- ids, y <- ids
, let diff = zipWith (\ a b -> if a == b then a else '!') x y
, length (filter (== '!') diff) == 1 ]
print $ filter (/= '!') diff
where
repeatCounts x = filter (x `elem`) . map (map length . group . sort)