There's one more important recursion pattern. Imagine you want the sum of all numbers of a list, so the function type signature would be: \begin{haskellcode} sum :: [Int] -> Int \end{haskellcode} Solution? \pause \begin{haskellcode} sum :: [Int] -> Int sum [] = 0 sum (x:xs) = x + sum xs \end{haskellcode} \pause Or the product: \begin{haskellcode} prod :: [Int] -> Int prod [] = 1 prod (x:xs) = x * prod xs \end{haskellcode} \pause Or the length: \begin{haskellcode} length :: [a] -> Int length [] = 0 length (x:xs) = 1 + length xs \end{haskellcode}