Add remaining haskell book exercises
This commit is contained in:
16
Haskell-book/13/Cipher.hs
Normal file
16
Haskell-book/13/Cipher.hs
Normal 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
|
||||
Reference in New Issue
Block a user