sicp 练习2.4

练习2.4  下面是序列对的另一种过程性表示方式

(define  (cons  x  y)

(lambda  (m)  (m  x  y)))

(define  (car  z)

(z  (lambda  (p  q)  p)))

以上是sicp(计算机程序的构造和解释)书中原内容。初看有点难以理解,正是这有点难理解的地方将scheme(或者lisp)的最精髓之处展现出来:1.过程(函数)可以作为参数,这早已知晓。2.值也可以是函数!!



上面程序的解释:cons接受两个参数x,y 后得到(cons  x  y)

(cons  x  y)并不是一个数据(值),而是接受一个参数m的函数

(+  2  3)是一个值,但是(cons  x  y)是一个函数。

(cons  x  y)接受参数m后,是(m  x  y)

继续看car函数:car接受参数z (很好理解),作用是把(lambda (p q) p)作为参数给z。即(z (lambda (p q) p))

执行(car (cons x y))  

=> 看car的作用,把(lambda (p q) p)作为参数给(cons x y) 

=> (cons x y)接受参数后,((lambda (p q) p) x y)

=> 得到x



最后,我们可以改写(car z)的定义:

(define car

(lambda (z)

(z (lambda (p q) p))))


以下是验证:


---------------------------------欢迎各种留言~

---------------------------------转载请注明出处~不注明也是可以的啦~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值