Haskell non exhaustive patterns in function

前端 未结 3 1274
粉色の甜心
粉色の甜心 2020-12-20 17:42

the following code compiles well but when i try to input helper 10 primes [] [] it gives me :Non-exhaustive patterns in function helper

primes = [2, 3, 5, 7,         


        
相关标签:
3条回答
  • 2020-12-20 17:48

    chinese3 has no case for the empty list.

    helper lacks several more cases, including one where the second argument has one element.

    0 讨论(0)
  • 2020-12-20 17:53

    Based on the first line of the definition of helper, it will match on an empty list ([]) in the second argument. Based on the second line, it will match on a list of at least two values in the second argument (x:y:xs). This leaves a single-item list unaccounted for.

    EDIT

    For the sake of simplicity, let's assume that primes is defined like this:

    primes = [2, 3, 5]
    

    Now when you evaluate this expression:

    helper 10 primes [] []
    

    Clearly it's the second part of the definition of helper that will get matched here (the first part would only match if primes were an empty list). Now based on the pattern for the second parameter (x:y:xs), we can see that x will be bound to 2, y will be bound to 3 and xs will be bound to [5]. In the definition of helper you are applying the function recursively using xs as the second argument. In other words, it looks something like this:

    helper 10 [5] ...
    

    Which case of the helper function will be used here? [5] is not an empty list, so not the first one. The second case? No, that case only matches against a list of at least two values (what value would y get bound to?). I hope you can now see that you have not accounted for when helper is called with a single item list as the second parameter (which in practice will happen any time you call helper with a list of an odd number of values in the second parameter).

    0 讨论(0)
  • 2020-12-20 18:15

    What you're trying to evaluate:

    helper 10 primes   []  []
    

    Your equations for helper:

    helper n  []       (v) _      = ...
    helper n  (x:y:xs) (v) (c:cs) = ...
    

    Let's try to match the first equation:

    • n = 10 matches
    • [] = primes does not match

    OK, let's try to match the second equation instead:

    • n = 10 matches
    • (x:y:xs) = primes matches, with
      • x = 2
      • y = 3
      • xs = [5, 7, 11, 13, ...]
    • v = [] matches
    • (c:cs) = [] does not match

    So neither pattern matches. We have a pattern match failure.

    0 讨论(0)
提交回复
热议问题