Midhun
Midhun

Reputation: 744

Lisp: to perform set union operation

I 'am a beginner in LISP.I use clisp in ubuntu.I have a code here in lisp to carry out union operation on two lists.The logic is correct.But stuck at an error which is:

*** - APPEND: A proper list must not end with T

my code is:

(defun set-union (L1 L2)
(cond 
 ((null L2)   ;if l2 is null then union is l1 itself. 
  L1) 
 ((not (member (first L2) L1))  ;check if first member of l2 is in l1 or not
  (setq l1 (append (set-union L1 (rest L2)) (list (first L2))))) ;if not then append it with the union of l1 and rest of l2.
 (t
  (set-union L1 (rest L2)))
  )) ;if second condition is not true then carry out union on l1 and rest of the elements of l2
(setq l1 (list 'a 'c 'b 'g))
(setq l2 (list 'd 'g 't))
(set-union l1 l2)
(print l1)

I Need help!!Thanks.

Upvotes: 0

Views: 495

Answers (1)

uselpa
uselpa

Reputation: 18917

(append (set-union L1 (rest L2)) (first L2))

at some point of your logic tries to append (A C B G . T) and E, which fails because the first is not a proper list.

Either use

(append (set-union L1 (rest L2)) (list (first L2)))

or, better

(cons (first L2) (set-union L1 (rest L2)))

Upvotes: 1

Related Questions