Add remaining haskell book exercises

This commit is contained in:
2025-12-11 10:28:11 +01:00
parent 3624c712d7
commit 98329e0a3d
221 changed files with 8033 additions and 2 deletions

16
Haskell-book/13/Cipher.hs Normal file
View File

@@ -0,0 +1,16 @@
module Cipher where
import Data.Char
import Data.List
vigenere :: String -> String
vigenere = f (cycle [0, 11, 11, 24])
where f _ [] = []
f ys (' ':xs) = ' ' : (f ys xs)
f (y:ys) (x:xs) = (decode (x, y)) : (f ys xs)
where decode (x, y) = chr ((mod ((ord x) - 65 + y) 26) + 65)
main :: IO ()
main = do
i <- getLine
putStrLn $ vigenere i