solutions block 5
parent
4a681a78dc
commit
0b1dc3c97f
|
@ -0,0 +1,12 @@
|
|||
addThreeNumbers :: Int -> Int -> Int -> Int
|
||||
addFive :: Int -> Int -> Int
|
||||
|
||||
addThreeNumbers x y z = x + y + z
|
||||
addFive = addThreeNumbers 5
|
||||
|
||||
-- Test cases
|
||||
main = do
|
||||
print (addThreeNumbers 3 2 4) -- 9
|
||||
print (addThreeNumbers 7 6 4) -- 17
|
||||
print (addFive 3 2) -- 10
|
||||
print (addFive 1 4) -- 10
|
|
@ -0,0 +1,22 @@
|
|||
module Main where
|
||||
|
||||
-- Definiert einen simplen container für unsere Werte
|
||||
data Box a = Box a deriving (Show, Eq)
|
||||
|
||||
-- Schreibe die Unit funktion, welche einen Wert in einen Container verschachtelt!
|
||||
unit :: a -> Box a
|
||||
unit x = Box x
|
||||
|
||||
-- Schreibe die Bind Funktion, welches es einem Erlaubt funktionen des Monadischen Typen Box zu verketten
|
||||
bind :: Box a -> (a -> Box b) -> Box b
|
||||
bind (Box x) f = f x
|
||||
|
||||
-- Schreibe eine Lift Funktion, welche eine Funtion nimmt und diesselbe funktion mit den Monadischen Werten als Eigabe und Ausgabetyp besitzt
|
||||
lift :: (a -> b) -> Box a -> Box b
|
||||
lift f (Box x) = Box (f x)
|
||||
|
||||
|
||||
-- Tests
|
||||
main :: IO ()
|
||||
main = do
|
||||
print $ unit 10 -- Box 10
|
|
@ -0,0 +1,26 @@
|
|||
module Main where
|
||||
|
||||
-- Definiere eine einfache Datenstruktur für DOM-Elemente
|
||||
data DOM a = Element a [DOM a] | EmptyElement deriving (Show, Eq)
|
||||
|
||||
-- Unit-Funktion: Verpackt einen Tag in einen DOM Element
|
||||
unit :: a -> DOM a
|
||||
unit x = Element x []
|
||||
|
||||
-- Bind-Funktion: Verknüpft Berechnungen für DOM-Elemente
|
||||
bind :: DOM a -> (a -> DOM b) -> DOM b
|
||||
bind EmptyElement _ = EmptyElement
|
||||
bind (Element x children) f =
|
||||
case f x of
|
||||
EmptyElement -> EmptyElement
|
||||
Element newX newChildren -> Element newX (newChildren ++ map (`bind` f) children)
|
||||
|
||||
-- Lift-Funktion: Hebt eine normale Funktion in den DOM-Kontext
|
||||
lift :: (a -> b) -> DOM a -> DOM b
|
||||
lift _ EmptyElement = EmptyElement
|
||||
lift f (Element x children) = Element (f x) (map (lift f) children)
|
||||
|
||||
-- Hauptfunktion zum Ausführen von Tests
|
||||
main :: IO ()
|
||||
main = do
|
||||
print $ unit "root" -- Element "root" []
|
|
@ -0,0 +1,8 @@
|
|||
doubleAndIncrement :: Int -> Int
|
||||
|
||||
doubleAndIncrement = (+1) . (*2)
|
||||
|
||||
-- Test cases
|
||||
main = do
|
||||
print (doubleAndIncrement 3) -- 7
|
||||
print (doubleAndIncrement 5) -- 11
|
|
@ -0,0 +1,13 @@
|
|||
multiplyBy :: Int -> (Int -> Int)
|
||||
double :: Int -> Int
|
||||
|
||||
multiplyBy = (*)
|
||||
double = multiplyBy 2
|
||||
triple = multiplyBy 3
|
||||
|
||||
|
||||
-- Test cases
|
||||
main = do
|
||||
print (double 4) -- Expected output: 8
|
||||
print (double 7) -- Expected output: 14
|
||||
print (triple 4) -- Expected output: 12
|
Loading…
Reference in New Issue