recursion - 避免双重递归

标签 recursion lisp

(DEFUN F(L)
   (COND
      ((NULL L) NIL)
      ((LISTP (CAR L))
       (APPEND (F (CAR L))
               (F (CDR L))
               (CAR (F (CAR L)))))
      (T (LIST (CAR L)))
))

该函数返回一个点对(如果第一个元素是一个子列表),右边是子列表的第一个元素,左边是右边的元素和列表的第二个元素(如果不是子列表)。现在,如何在不使用 (F (CAR L)) 的双重递归和不使用 SET,SETQ,SETF 的情况下重写它?

最佳答案

使用 LET 将局部变量绑定(bind)到重复的递归调用。

(DEFUN F(L)
   (COND
      ((NULL L) NIL)
      ((LISTP (CAR L))
       (LET ((FCAR (F CAR L)))
         (APPEND FCAR
                 (F (CDR L))
                 (CAR FCAR))))
      (T (LIST (CAR L)))
))

关于recursion - 避免双重递归,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20960920/

相关文章:

clojure - 如何评估 Clojure 中的纯函数序列

lisp - lisp 中的自定义 '+'(求和)函数

lisp - 如何在tinyscheme中写入文件?

c++ - 指针在退出递归函数后更改其地址

python - 谁能告诉我这个函数的递归部分是如何工作的?

Java程序递归反转数组

templates - 如何在编译时捕获递归函数的结果?

algorithm - "dovetailing"是什么意思?

math - Lisp -- 如何在不进行基数转换的情况下将多个十六进制数相加?

macros - 不带 eval 取消引用