SICP Section 2.1.3

Exercise 2.4

#lang racket
(define (cons x y)
  (lambda (m) (m x y)))
(define (car z)
  (z (lambda (p q) p)))
;(cons x y) return a procedure (lambda (m) (m x y))
;that takes a procedure m as argument and calls it on its two own arguments.
;so,we pass m the procedure (lambda (p q) p) which need two paramters
;hence,it applys x->p,y->q,and produces the result x.

;the cdr procedure
(define (cdr z)
  (z (lambda (p q) q)))

Exercise 2.5

#lang racket
;can b divide by a?
(define (divide? a b)
  (= (remainder b a) 0))
;expt need two arguments,one is base
(define (my-cons a b)
  (* (expt 2 a) (expt 3 b)))
;get exponent a
(define (my-car c)
  (define (mid-car c n)
    (cond ((not (divide? 2 c)) n)
          (else (mid-car (/ c 2) (+ n 1)))))
  (mid-car c 0))
;get exponent b
(define (my-cdr c)
  (define (mid-car c n)
    (cond ((not (divide? 3 c)) n)
          (else (mid-car (/ c 3) (+ n 1)))))
  (mid-car c 0))

Exercise 2.6

#lang racket
;zero-fold combination f on x
(define zero
  (lambda (f) 
    (lambda (x)
      x)))
(define (add-1 n)
  (lambda (f)
    (lambda (x)
      (f ((n f) x)))))
;one-fold combination f on x
(define one
  (lambda (f)
    (lambda (x)
      (f x))))
;two-fold combination f on x
(define two
  (lambda (f)
    (lambda (x)
      (f (f x)))))
;(a+b)-fold combination f on x
(define (add a b)
  (lambda (f)
    (lambda (x) ((a f) ((b f) x)))))

Summarize

  1. 书中提到的message passing方法,就像一个调度器,使我们可以在一个方法里实现很多任务,使程序更好的模块化。
  2. 方法即数据?确实很让人困惑,但是书中示例中的方法确实满足了数据的要求。更进一步看,Lisp是可以传递方法的,这种强大的语言特性,不仅使我们可以抽象各种各样的通用操作,更是我们可以用方法解释方法成为现实,或者说,更直接一些(在面向对象的语言中,我们传递的数据是对象,其实更是对象中数据跟方法)。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
"SICP中文版"是指计算机科学经典教材《Structure and Interpretation of Computer Programs》(计算机程序的构造和解释)的中文翻译PDF版。这本教材由麻省理工学院的Harold Abelson和Gerald Jay Sussman等人编写,是计算机科学领域中一本重要的教材。 "SICP中文版PDF"提供了更方便的学习方式。无论是学生、程序员还是计算机科学爱好者,都可以在任何时候通过电子设备访问和学习这本教材。使用PDF格式的好处是可以在不同的平台上都能打开和阅读,而不受限于特定的操作系统或设备。 通过"SICP中文版PDF",读者可以学习计算机科学的基本原理和概念,如过程、数据抽象、递归、高阶函数、并发等。这本教材以Scheme语言为示例,帮助读者理解计算机程序的结构、设计和解释。通过逐步的案例和练习,读者可以锻炼解决问题和编写高质量代码的能力。 "SICP中文版PDF"也提供了沟通和讨论的平台。读者可以通过在线社群或论坛,与其他人分享学习心得、解答疑问和参与讨论。这为读者提供了一个学习交流的机会,促进了学习者之间的互动和共同成长。 总之,"SICP中文版PDF"是一本经典的计算机科学教材的中文翻译版本,使得更多的读者可以方便地学习和掌握其中的知识。无论是对于计算机科学专业的学生还是对计算机科学感兴趣的人,这本教材都是一本很好的参考书,并提供了丰富的实例和练习,让读者深入理解计算机程序的核心概念和设计原则。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值