haskell-lectures/VL2/content/VL2_fold2.tex

19 lines
1.2 KiB
TeX
Raw Permalink Normal View History

2015-04-23 19:34:47 +00:00
\ifger{Um es kurz zu machen, die abstrakte Lösung ist:}{To cut the story short, the abstract solution looks like this:}
\begin{haskellcode}
2015-05-02 15:51:23 +00:00
fold :: (a -> b -> b) -> b -> [a] -> b
fold f z [] = z
fold f z (x:xs) = x `f` (fold f z xs)
\end{haskellcode}
Whoa! What's going on here?\\
2015-04-23 19:34:47 +00:00
\ifger{Schauen wir genauer hin...}{Let's see...}
\begin{itemizep}
2015-04-23 19:34:47 +00:00
\item \hinline{f} \ifger{ist unsere Funktion}{is our function} (\ifger{z.b.}{e.g.} \hinline{(*)} \ifger{oder}{or} \hinline{(+)})
2015-05-02 15:51:23 +00:00
\item \hinline{z} \ifger{ist was die Funktion zurückgibt, wenn die Liste leer ist}{is what we return if the list is empty}
2015-04-23 19:34:47 +00:00
\item \ifger{das letzte Argument ist die eigentliche Liste, auf der wir arbeiten}{and the last remaining argument is the actual list we are working on}
\end{itemizep}
\slidep
2015-04-23 19:34:47 +00:00
\ifger{Die Funktionsanwendung hat die folgende Form:}{The function application has the following form:}\\
\hinline{fold f z [a,b,c] == a `f` (b `f` (c `f` z))}
\vspace{\baselineskip}
\\
2015-04-23 19:34:47 +00:00
\ifger{D.h. hier falten wir von rechts. \emph{Prelude} definiert diese Funktion bereits, die fast genauso ist wie unsere. Sie heisst \textbf{foldr}.}{This folds from the right, so the \emph{Prelude} already defines a function which is very similar to ours and called \textbf{foldr}.}