我是lisp的初学者。我使用clisp in ubuntu.I,在lisp中有一个代码在lisp上执行联合操作,lists.The逻辑是correct.But卡在一个错误上的,这是:
*** - APPEND: A proper list must not end with T
我的代码是:
(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)我需要帮助!!谢谢。
发布于 2015-10-31 05:43:11
(append (set-union L1 (rest L2)) (first L2))在某种程度上,你的逻辑试图追加 (A,C,B,G)。和E,因为第一个不是正确的列表而失败。
要么使用
(append (set-union L1 (rest L2)) (list (first L2)))或者更好
(cons (first L2) (set-union L1 (rest L2)))https://stackoverflow.com/questions/33447794
复制相似问题