Tarion
Tarion

Reputation: 17134

Haskell tail function for empty lists

I have a problem with a function that should only return the tail of a list. The functions is myTail and should give a useable result, even if the input is an empty list.

I want to understand all 3 ways: pattern matching, guarded equation and conditional expressions

this works:

> myTail_pat :: [a] -> [a]

> myTail_pat (x:xs) = xs
> myTail_pat [] = []

But this:

> myTail_guard (x:xs)   | null xs = []
>               | otherwise = xs

gives me the error: Program error: pattern match failure: myTail_guard [] How can i declare the function without patterns?

Thank you.

Upvotes: 9

Views: 11360

Answers (2)

Ilya Kharlamov
Ilya Kharlamov

Reputation: 3932

drop 1 is safe

drop 1 []
-- result: []

Upvotes: 13

Chuck
Chuck

Reputation: 237060

The pattern x:xs does not match the empty list. You'd need to do:

myTail_guard xs
  | null xs   = []
  | otherwise = tail xs

Upvotes: 17

Related Questions