SICP Exercise 1.1 to Exercise 1.6

[size=medium]
Exercise 1.1 This exercise is very easy, just evaluate some expressions.[/size]

1 ]=> 10

;Value: 10

1 ]=> (+ 5 3 4)

;Value: 12

1 ]=> (- 9 1)

;Value: 8

1 ]=> (/ 6 2)

;Value: 3

1 ]=> (+ (* 2 4) (- 4 6))

;Value: 6

1 ]=> (define a 3)

;Value: a

1 ]=> (define b (+ a 1))

;Value: b

1 ]=> (+ a b (* a b))

;Value: 19

1 ]=> (= a b)

;Value: #f

1 ]=> (if (and (> b a) (< b (* a b)))
b
a)

;Value: 4

1 ]=> (cond ((= a 4) 6)
((= b 4) (+ 6 7 a))
(else 25))

;Value: 16

[size=medium]Exercise 1.2 Define a procedure that takes three numbers as arguments and returns the sum of the squares of the two larger numbers.

Solution: First, find the smallest number of three numbers. So the result is the sum of the squares of three numbers subtract the square of the smallest number.[/size]


(define (sum-of-square-bigers x y z)
(let ((minimum (min x y z)))
(- (+ (square x)
(square y)
(square z))
(square minimum))))

[size=medium]Exercise 1.3 Ben Bitdiddle has invented a test to determine whether the interpreter he is faced with is using applicative-order evaluation or normal-order evaluation. He defines the following two procedures:[/size]

(define (p) (p))
(define (test x y)
(if (= x 0)
0
y))

Then he evaluates the expression
(test 0 (p))

[size=medium]What behavior will Ben observe with an interpreter that uses applicative-order evaluation? What behavior will he observe with an interpreter that uses normal-order evaluation? Explain your answer.

[/size]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值