Day 25: Code Chronicle

Megathread guidelines

  • Keep top level comments as only solutions, if you want to say something other than a solution put it in a new post. (replies to comments can be whatever)
  • You can send code in code blocks by using three backticks, the code, and then three backticks or use something such as https://topaz.github.io/paste/ if you prefer sending it through a URL

FAQ

  • LeixB@lemmy.world
    link
    fedilink
    arrow-up
    3
    ·
    2 days ago

    Haskell

    Merry Christmas!

    {-# LANGUAGE OverloadedStrings #-}
    
    module Main where
    
    import Data.Either
    import Data.Text hiding (all, head, zipWith)
    import Data.Text qualified as T
    import Data.Text.IO as TIO
    
    type Pins = [Int]
    
    toKeyLock :: [Text] -> Either Pins Pins
    toKeyLock v = (if T.head (head v) == '#' then Left else Right) $ fmap (pred . count "#") v
    
    solve keys locks = sum [1 | k <- keys, l <- locks, fit k l]
      where
        fit a b = all (<= 5) $ zipWith (+) a b
    
    main = TIO.getContents >>= print . uncurry solve . partitionEithers . fmap (toKeyLock . transpose . T.lines) . splitOn "\n\n"