2015-04-19 22:32:01 +00:00
|
|
|
Again, we can do pattern matching on lists.
|
|
|
|
\begin{haskellcode}
|
|
|
|
listLen :: [Integer] -> Integer
|
|
|
|
listLen [] = 0
|
|
|
|
listLen (x:xs) = 1 + listLen xs
|
|
|
|
\end{haskellcode}
|
|
|
|
\pause
|
|
|
|
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}
|
2015-04-20 18:55:41 +00:00
|
|
|
Note that \hinline{(x:(y:zs))} may also be written as \hinline{(x:y:zs)}.
|