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

【SICP练习】142 练习3.77

时间:2015-03-29 13:45:57      阅读:101      评论:0      收藏:0      [点我收藏+]

标签:infinite   stream   definition   section   procedure   

练习3-77

原文

Exercise 3.77. The integral procedure used above was analogous to the “implicit” definition of the infinite stream of integers in section 3.5.2. Alternatively, we can give a definition of integral that is more like integers-starting-from (also in section 3.5.2):

(define (integral integrand initial-value dt)
   (cons-stream initial-value            
                (if (stream-null? integrand)         
                    the-empty-stream           
                    (integral (stream-cdr integrand)                             
                              (+ (* dt (stream-car integrand))                                
                                 initial-value)                             
                              dt))))

When used in systems with loops, this procedure has the same problem as does our original version of integral. Modify the procedure so that it expects the integrand as a delayed argument and hence can be used in the solve procedure shown above.

代码

 (define (integral delayed-integrand initial-value dt) 
         (cons-stream initial-value 
                 (let ((integrand (force delayed-integrand))) 
                         (if (stream-null? integrand) 
                                 the-empty-stream 
                                 (integral (delay (stream-cdr integrand)) 
                                           (+ (* dt (stream-car integrand)) 
                                                      initial-value) 
                                                dt))))) 

【SICP练习】142 练习3.77

标签:infinite   stream   definition   section   procedure   

原文地址:http://blog.csdn.net/nomasp/article/details/44725731

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