recursion - 这个 lisp 示例是否以尾递归为特色?

标签 recursion lisp common-lisp tail-recursion

我的理解是尾递归是不需要返回值来完成操作的递归;也就是说,递归是函数的最后一步,函数的其余部分在进行递归调用后完成。

为此,我问这个例子(来自 Mr. Norvig)是否是尾递归:

(defparameter *titles*
  '(Mr Mrs Miss Ms Sir Madam Dr Admiral Major General)
  "A list of titles that can appear at the start of a name.")

(defun first-name (name)
  "Select the first name from a name represented as a list." 
  (if (member (first name) *titles*)
     (first-name (rest name))
     (first name)))

一次决赛first-name被称为 if 的分支语句,函数没有别的作用;所以是尾递归?

最佳答案

是的,这是一个例子。

尾递归优化在 Common Lisp 的许多实现中都可用,但规范并不要求它。 这意味着您可以拥有一个没有尾递归优化的 Common Lisp。

您可能还会发现您正在使用的版本需要稍加修改才能执行此优化。

因此在某些实现中,您可能需要使用“声明”来通知您的编译器您想要优化速度。

(defun first-name (name)
  "Select the first name from a name represented as a list." 
  (declare (optimize (speed 3) (compilation-speed 0) (debug 0) (safety 1)))
  (if (member (first name) *titles*)
      (first-name (rest name)) 
      (first name)))

编辑: This site现在已经有几年了,但可能会提供一些信息。

另外请务必阅读评论,因为 Joshua 和 Rainer 对此处的细节进行了大量改进。

关于recursion - 这个 lisp 示例是否以尾递归为特色?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19953088/

相关文章:

javascript - 如何在递归函数中跳出 for 循环并在 Javascript 中返回?

没有isinstance的列表列表上的python递归(不同)

java - 使用此函数查找使用操作(+、- 和 concat)将数字 1 - 9 添加到总和的表达式时,我哪里出错了?

recursion - Clojure 什么时候检查 recur 是否出现在尾部位置?

lisp - 在 cygwin 上安装 sbcl

c# - int ref 参数是否被装箱?

recursion - 使用 CPS 删除 Scheme 中的子序列函数(深度递归)

sql - 使用后现代将 json 数据插入 postgresql 数据库

if-statement - 如何在 if 语句中使用 (or)?

testing - 如何在 SBCL 中运行测试文件