aboutsummaryrefslogtreecommitdiff
path: root/Haskell-book/13/Palindrome.hs
diff options
context:
space:
mode:
authorEugen Wissner <belka@caraus.de>2025-12-11 10:28:11 +0100
committerEugen Wissner <belka@caraus.de>2025-12-11 10:28:11 +0100
commit98329e0a3dd4f78b5d815ac3896272ec70904901 (patch)
tree80f9c56cfe2ac20232358f236d32e84bd683be1b /Haskell-book/13/Palindrome.hs
parent3624c712d72d246f21d4e710cec7c11e052e0326 (diff)
downloadbook-exercises-98329e0a3dd4f78b5d815ac3896272ec70904901.tar.gz
Add remaining haskell book exercises
Diffstat (limited to 'Haskell-book/13/Palindrome.hs')
-rw-r--r--Haskell-book/13/Palindrome.hs20
1 files changed, 20 insertions, 0 deletions
diff --git a/Haskell-book/13/Palindrome.hs b/Haskell-book/13/Palindrome.hs
new file mode 100644
index 0000000..439c980
--- /dev/null
+++ b/Haskell-book/13/Palindrome.hs
@@ -0,0 +1,20 @@
+module Palindrome where
+
+import Control.Monad
+import Data.Char
+import System.Exit
+
+format :: String -> String
+format s = filter (\x -> x >= 'a' && x <= 'z') (map toLower s)
+
+palindrome :: IO ()
+palindrome = forever $ do
+ line1 <- getLine
+ case ((format line1) == (format $ reverse line1)) of
+ True -> putStrLn "It's a palindrome!"
+ False -> do
+ putStrLn "Nope!"
+ exitSuccess
+
+main :: IO ()
+main = palindrome