SICP习题 1.17 (用加法求乘积)

递归乘法算法
本文介绍了一种使用递归方式实现的乘法算法,该算法通过判断乘数的奇偶性来选择不同的递归调用策略,实现了两个整数相乘的功能。文中给出了具体的Scheme语言实现代码。
(define (double x)
  (+ x x))

(define (halve x)
  (/ x 2))

(define (mult a b)
  (cond ((= b 0) 0)
        ((even? b) (double (mult a (halve b))))
        ((odd? b) (+ a (mult a (- b 1))))))

(mult 12 12)

  

(define (double x)
  (+ x x))

(define (halve x)
  (/ x 2))

(define (mult a b)
  (cond ((= b 0) 0)
        ((even? b) (mult (double a) (halve b)))
        ((odd? b) (+ a (mult a (- b 1))))))

(mult 12 12)

  

转载于:https://www.cnblogs.com/R4mble/p/7889795.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值