1

下面的代码不断抛出以下错误:

 caught ERROR:

illegal function call

     (LET ((SOLUTION 'NIL) (FIRST 0) (SECOND 0))
       (DOLIST (EL LST)
         (IF (NUMBERP EL)
             (PUSH EL SOLUTION)
             ((SETF #) (SETF #) (PUSH # SOLUTION))))
       (CAR SOLUTION))

谁能明白为什么?从语法上讲,我看不出它有什么问题。注意:我正在使用 sbcl。

我的代码:

(defun evalpostfix (lst)
  (let ((solution '())
        (first 0)
        (second 0))
    (dolist (el lst)
      (if (numberp el) ;if
          (push el solution) ;then
          ((setf second (pop solution)) ;else
             (setf first (pop solution))
             (push (funcall el first second) solution))))
    (car solution)))
4

2 回答 2

5

((setf second (pop solution))- 两个左括号?为什么?IF使用 else 形式的语法是:

(if test-form then-form else-form)

表单不能以两个括号开头 - 只有一个例外:((lambda (x) (+ x 1)) 2).

如果您想对多个表达式进行分组,请使用类似(progn a b c ... z).

于 2013-04-14T18:10:22.477 回答
0

实际上,为了将多个表单组合在一起,请使用特殊运算符progn

您可以更进一步,将后续setf调用组合在一起:

(setf second (pop solution)
      first  (pop solution))
于 2013-04-15T09:10:39.447 回答