码迷,mamicode.com
首页 > 其他好文 > 详细

SICP 1.37 1.38 1.39

时间:2014-08-28 01:01:08      阅读:238      评论:0      收藏:0      [点我收藏+]

标签:style   os   ar   sp   line   on   new   size   ef   

解:1.37

(define tolerance 0.00001)

(define (average x y)
  (/ (+ x y) 2.0))

(define (fixed-point f first-guess)
  (define (close-enought? v1 v2)
    (< (abs (- v1 v2)) tolerance))
  (define (try guess)
    (display guess)
    (newline)
    (let ((next (f guess)))
      (if (close-enought? guess next)
          next
          (try next))))
  (try first-guess))

(define (cont-frac n d k)
  (define (calc i)
    (if (> i k)
        0
        (/ (n i) (+ (d i) (calc (+ i 1))))))
  (calc 1))

(define (cont-frac-iter n d k)
  (define (calc i result)
    (if (= i 0)
        result
        (calc (- i 1) (/ (n i) (+ (d i) result)))))
  (calc k 0))


1.38

(define (calc-e k)
  (define (d i)
    (let ((r (remainder i 3)))
      (if (or (= r 0) (= r 1))
          1
          (+ 2 (* (floor (/ i 3)) 2)))))
  (+ 2 (cont-frac-iter (lambda (x) 1.0) d k)))


1.39

N函数要注意另上负号

(define (tan-cf x k)
  (define (n i)
    (if (= i 1)
        x
        (- (* x x))))
  (define (d i)
    (- (* 2 i) 1))
  (cont-frac-iter n d k))


SICP 1.37 1.38 1.39

标签:style   os   ar   sp   line   on   new   size   ef   

原文地址:http://my.oschina.net/u/1445655/blog/307427

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!