SICP 1.16 1.17 1.18

解:

公共过程

(define (even? n)
  (= (remainder n 2) 0))

(define (double n)
  (+ n n))

(define (halve n)
  (/ n 2))


1.16:

(define (expt b n)
  (define (iter b n a)
    (cond ((= n 0) a)
          ((even? n) (iter (* b b) (/ n 2) a))
          (else (iter b (- n 1) (* b a)))))
  (iter b n 1))

1.17 1.18

    = 2*(a*(b/2))=a*(b/2)+a*(b/2)=2a*(b/2),b是偶数

a*b = a+a*(b-1),b是奇数

    = a,b=1

(define (multiply a b)
  (define (fast-mul a b)
    (cond ((= b 1) a)
          ((even? b) (double (fast-mul a (halve b))))
          (else (+ a (fast-mul a (- b 1))))))
  (fast-mul a b))

(define (multiply2 a b)
  (define (fast-mul a b c)
    (cond ((= b 1) (+ a c))
          ((even? b) (fast-mul (double a) (halve b) c))
          (else (fast-mul a (- b 1) (+ a c)))))
  (fast-mul a b 0))

转载于:https://my.oschina.net/guzhou/blog/295062

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值