微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

我需要我的函数使用 LISP while 循环和 Euclids 算法返回给定输入的 GCD 我得到的输出是 0

如何解决我需要我的函数使用 LISP while 循环和 Euclids 算法返回给定输入的 GCD 我得到的输出是 0

(defun gcd (n·m) “返回任意两个输入值的 gcd。” (let ((dividend n) (divisor m) (remainder 1)) (条件 ((> 纳米) (gcd m n)) ((

(gcd 12 18) 00

解决方法

我真的不知道你的代码有什么问题。但是,如果我们考虑使用 lisp 语言,我认为您的方法不是最好的。最好写一个递归函数:它更短而且 - 恕我直言 - 更漂亮。

(defun gcd (n m)
  (cond ((< n m) (gcd m n))
        ((= m 0) n)
        (t (gcd m (% n m)))))

重点是尾递归的概念,它实际上是一个公平的循环而不是这个递归函数,所以你不会得到任何堆栈溢出错误。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。