函数 f 是递归实现
函数 f1 是迭代实现
(define (f n)
(cond ((< n 3) n)
(else (+ (f (- n 1))
(* 2 (f (- n 2)))
(* 3 (f (- n 3)))))))
(define (f1 n)
(f2 2 1 0 n))
(define (f2 a b c n)
(cond ((< n 2) n)
((= n 2) a)
(else (f2 (+ a (* 2 b) (* 3 c)) a b (- n 1)))))
这篇博客探讨了SICP中的习题1.11,详细分析了如何使用递归和迭代两种方式来实现函数 f 和 f1。递归实现通常涉及函数自身调用,而迭代实现则通过循环结构来达成相同目标。
3290

被折叠的 条评论
为什么被折叠?



