Check if item is in a list (Lisp)

54,008

Solution 1

Common Lisp

FIND is not a good idea:

> (find nil '(nil nil))
NIL

Above would mean that NIL is not in the list (NIL NIL) - which is wrong.

The purpose of FIND is not to check for membership, but to find an element, which satisfies a test (in the above example the test function is the usual default EQL). FIND returns such an element.

Use MEMBER:

> (member nil '(nil nil))
(NIL NIL)  ; everything non-NIL is true

or POSITION:

> (numberp (position nil '()))
NIL

Solution 2

Use MEMBER to test whether an item is in a list:

(member 1 '(5 9 1 2))  ; (1 2)

Unlike FIND, it is also able to test whether NIL is in the list.

Solution 3

You can use find:

(find 1 '(5 9 1 2)) ; 1
(find 7 '(5 9 1 2)) ; nil

Consider using :test argument:

(find "a" '("a" "b") :test #'equal)
Share:
54,008
Jeff
Author by

Jeff

Updated on January 05, 2020

Comments

  • Jeff
    Jeff over 4 years

    What's a simple way to check if an item is in a list?

    Something like

    (in item list)
    

    might return true if item=1 and list=(5 9 1 2) and false if item=7