加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

【SICP练习】2 练习1.6

发布时间:2020-12-14 01:25:53 所属栏目:百科 来源:网络整理
导读:?? 练习 1.6 这道题通过由一个新版本的 if 来引出,主要讨论的还是应用序和正则序的问题。我看到“将 if 提供为一种特殊形式”时还满头雾水,并不太清楚什么特殊形式。当再返回看 if 的语法时才发现,这在第 12 页 if 的一般表达式下面一段。如果 predicate
??

练习1.6

这道题通过由一个新版本的if来引出,主要讨论的还是应用序和正则序的问题。我看到“将if提供为一种特殊形式”时还满头雾水,并不太清楚什么特殊形式。当再返回看if的语法时才发现,这在第12if的一般表达式下面一段。如果<predicate>得到真值,解释器就去求值<consequent>并返回其值。注意,在此处已经返回其值了,并没有进行后续运算。

而通过cond写出来的常规过程的if,在解释器采用应用序求值的情况下,如果第一次运算good-enough?时为真,则直接返回了guess

原文中的求平方根的程序:

(define (new-if predicate then-clauseelse-clause)

(cond(predicate then-clause)

(elseelse-clause)))

(define (sqrt-iter guess x)

(new-if(good-enough? guess x)

guess

(sqrt-iter (improve guess x)

x)))

(define(sqrt-iter guess x)

(if(good-enough? guess x)

guess

(sqrt-iter (improve guess x)

x)))

于是博主进行了如下测试:

(sqrt-iter 3.00009155413 9)

;Aborting!: maximum recursion depthexceeded

由此看来,解释器直接得出了超过最大递归深度的中止结果。

对此并不理解,后来才发现3.00009155413的平方减去9其结果为0.000549333162并不小于0.0001

于是又将3.000001的平方当作guess传入sqrt-iter,结果再次出乎意料,依旧是超过最大递归深度。

希望弄清楚这个问题的网友们能够予以回复咯。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读