## Exercise from Grahams "Ansi Common Lisp"

You have problems, and we're glad to hear them. Explain the problem, what you have tried, and where you got stuck.
Feel free to share a little info on yourself and the course.
Forum rules
Please respect your teacher's guidelines. Homework is a learning tool. If we just post answers, we aren't actually helping. When you post questions, be sure to show what you have tried or what you don't understand.

### Exercise from Grahams "Ansi Common Lisp"

Hello, I'm a LISP-Beginner and I'm working through Paul Grahams book.

There is an exercise: Define a function that takes a list as an argument and return true
if one of its elements is a list.

I tried:
Code: Select all
`(defun my-find (lst)(if (listp (car lst))t(my-find (cdr lst))))`

But it will return true even if there is no list inside my list.
Could anyone please tell me what's wrong?
Thank You
freeside

Posts: 2
Joined: Sat Mar 18, 2017 4:16 am

### Re: Exercise from Grahams "Ansi Common Lisp"

In Common Lisp, NIL is an empty list, every list ends in NIL, and an empty list is NIL. '() is NIL, (CAR NIL) is NIL, (CDR NIL) is NIL, and (LISTP NIL) is T.

...

nuntius

Posts: 532
Joined: Sat Aug 09, 2008 10:44 am
Location: Newton, MA

### Re: Exercise from Grahams "Ansi Common Lisp"

Ok. So I have to test if there's a list except for the empty list.

Thank You.
freeside

Posts: 2
Joined: Sat Mar 18, 2017 4:16 am

### Re: Exercise from Grahams "Ansi Common Lisp"

The reason fo that is because you have no stop condition for when the function has failed to find a sublist. the final tail of a proper list is nil and (car nil) is nil. nil is a list.

The logic must check if the list is the empty list and return nil.
if it is not then you can do the rest your function is doing and it will work.
Since this will have 3 terms I would have used cond instead of if but that is just a style suggestion.

Thus:
Code: Select all
`(list-element-p '())          ; ==> nil(list-element-p '(1))         ; ==> nil(list-element-p '((1)))       ; ==> t(list-element-p '(nil))       ; ==> t(list-element-p '(1 2 (3)))   ; ==> t`
I'm the author of two useless languages that uses BF as target machine.
Currently I'm planning a Scheme compiler :p
sylwester

Posts: 130
Joined: Mon Jul 11, 2011 2:53 pm

Return to Homework

### Who is online

Users browsing this forum: No registered users and 1 guest