haskell-lectures/VL2/content/VL2_fold3.tex

14 lines
521 B
TeX
Raw Permalink Normal View History

2015-04-23 19:34:47 +00:00
\ifger{Jetzt wollen wir uns unsere Funktionen}{So how do our} \hinline{sum}, \hinline{prod} \ifger{und}{and} \hinline{length} \ifger{anschauen, wenn wir sie mittels \hinline{fold} implementieren:}{functions look like if we use our \hinline{fold} abstraction?}
\pause
\begin{haskellcode}
sum :: [Int] -> Int
2015-05-02 15:51:23 +00:00
sum xs = fold (\x y -> x + y) 0 xs
-- a Haskeller would write
2015-05-02 15:51:23 +00:00
sum = fold (+) 0
prod :: [Int] -> Int
2015-05-02 15:51:23 +00:00
prod xs = fold (\x y -> x * y) 1 xs
length :: [a] -> Int
2015-05-02 15:51:23 +00:00
length xs = fold (\x y -> 1 + y) 0 xs
\end{haskellcode}