\ifger{Erneut können wir pattern matching anwenden, auch auf Listen.}{Again, we can do pattern matching on lists.} \begin{haskellcode} listLen :: [Integer] -> Integer listLen [] = 0 listLen (x:xs) = 1 + listLen xs \end{haskellcode} \pause \ifger{Pattern matching können wir auch schachteln:}{We can also nest pattern matching:} \begin{haskellcode} sumEveryTwo :: [Integer] -> [Integer] sumEveryTwo [] = 0 sumEveryTwo (x:[]) = [x] sumEveryTwo (x:(y:zs)) = (x + y) : sumEveryTwo zs \end{haskellcode} \ifger{Hinweis...}{Note that} \hinline{(x:(y:zs))} \ifger{kann man auch als}{may also be written as} \hinline{(x:y:zs)}\ifger{ schreiben.}{.}