-- | The Prelude defines the most common data types and functions for -- | us, but the LANGUAGE construct at the top of the page excludes the -- | normally automatically imported Prelude. Here we add back in what -- | we might need in this module. import Prelude (Show, IO, Int, String, putStrLn, ($), show, (++), (+), (-), (*)) -- | our own version of a list datatype data Lst a = NIL | Cons a (Lst a) deriving (Show) -- | our own version of a boolean datatype data Booly = Yep | Nope deriving (Show) -- | Returns true if an instance of @Lst@ is empty, false otherwise isEmpty :: Lst a -> Booly isEmpty NIL = Yep isEmpty _ = Nope {-| An example list of integers 1 - 4 -} ex01 :: Lst Int ex01 = Cons 1 (Cons 2 (Cons 3 (Cons 4 NIL))) {-| Doubles the input parameter -} dub :: Int -> Int dub n = n * 2 {-| Apply a function to eeach element in a list to produce a new list -} lstMap :: (a -> b) -> Lst a -> Lst b lstMap _ NIL = NIL lstMap f (Cons x xs) = Cons (f x) (lstMap f xs) {-| Makes a string of repeated strings -} makeStringOf :: String -> Int -> String makeStringOf _ 0 = "" makeStringOf s n = s ++ (makeStringOf s (n - 1)) {-| Makes a string of asterisks -} makeStringOfStars :: Int -> String makeStringOfStars n = makeStringOf "*" n {-| Turn a list of integers to a list of strings of asterisks where each string of asterisks represents the integer from the original list -} histogramOf :: Lst Int -> Lst String histogramOf nums = lstMap makeStringOfStars nums main :: IO () main = do putStrLn $ "ex1 : " ++ (show ex01) putStrLn $ "doubled ex1 : " ++ (show (lstMap dub ex01)) putStrLn $ "histogram : " ++ (show (histogramOf ex01))