博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【SICP练习】150 练习4.6
阅读量:6183 次
发布时间:2019-06-21

本文共 1118 字,大约阅读时间需要 3 分钟。

练习4-6

原文

Exercise 4.6. Let expressions are derived expressions, because

(let (( ) … ( )) )
is equivalent to
((lambda ( … ) ) )
Implement a syntactic transformation let->combination that reduces evaluating let expressions to evaluating combinations of the type shown above, and add the appropriate clause to eval to handle let expressions.

分析

这道题需要我们将let表达式转换成相应的表达式。

(let (( ) … ( )) )

从上面的示例我们可以看到在let表达中,假设其为expr,用cdr可以得到(( ) … ( )),然后再用高阶函数map搭配car来取出所有的var。

同样的,如果要取出exp部分,先用cadr,再用高阶函数map搭配cadr。

而body部分用caddr就可以直接求出了。

然后就可以开始写let->combination,其传入一个参数expr。

((lambda ( … ) ) )

根据这段示例代码呢,我们先调用书中第256页的make-lambda来构造前面的一部,这个函数有两个参数parameter和body。

这样一来就全部都完成了,当然了,还需要将let?加入到eval中,在此之前也要定义let?。同样要调用第256页的tagged-list?。那么接下来就是具体的代码咯。

代码

(define (let-vars expr) (map car (cadr expr)))(define (let-exp expr) (map cadr (cadr expr)))(define (let-body expr) (caddr expr))(define (let->combination expr)  (cons (make-lambda (let-vars expr) (let-body expr))    (let-exp expr)))(define (let? expr) (tagged-list? expr 'let))((let? expr) (eval (let->combination expr) env))



感谢您的访问,希望对您有所帮助。

欢迎大家关注或收藏、评论或点赞。


为使本文得到斧正和提问,转载请注明出处:


你可能感兴趣的文章
编写基于PHP扩展库的后门
查看>>
Android Handler机制之Message及Message回收机制
查看>>
JSON vs Js
查看>>
css居中
查看>>
谈谈分享邀请奖励机制(附iOS实现代码)
查看>>
多隆:淘宝第一行代码撰写者的程序世界
查看>>
【刷算法】翻转单链表的递归和非递归方法
查看>>
基于JS快速生成各种网格布局工具Grid介绍
查看>>
十步零基础JavaScript学习路径
查看>>
vue-cli 3.0新特性解读
查看>>
第一个tensorflow程序
查看>>
从问题出发看JAVA编程规范
查看>>
【译】Swift算法俱乐部-快速排序
查看>>
150年前,他对拿破仑做数据可视化
查看>>
Kafka走查
查看>>
Ribbon 框架简介及搭建
查看>>
Vue 模板编程实践 之 巧用过滤器
查看>>
Node.js 服务器
查看>>
小议JS原型链、继承
查看>>
对比几段代码,看看你是 Python 菜鸟还是老鸟
查看>>