要求产生时间复杂度为logn的求幂程序
对幂数n分2种情况讨论,当n为偶数或者奇数两种情况讨论,并设置变量a存储迭代的计算结果。
(define (fast-expt b n)(expt-iter b n 1))(define (expt-iter b n a)(cond ((= n 0)a)((even? n)(expt-iter (square b)(/ n 2)a))((odd? n)(expt-iter b(- n 1)(* b a)))))
odd?是否为奇数
even?是否为偶数