zoukankan      html  css  js  c++  java
  • SICP_2.7-2.11

    
    
    (define (make-interval x y)
      (cons x y))
    
    (define (add-interval x y)
      (make-interval (+ (lower-bound x) (lower-bound y))
                    (+ (upper-bound x) (upper-bound y))))
    
    ;;;;;;;;;;;;;;;2.7
    (define (upper-bound inter)
      (cdr inter))
    
    (define (lower-bound inter)
      (car inter))
    ;;;;;;;;;;;;;;2.8
    (define (sub-interval x y)
      (add-interval x
                    (make-interval (- (upper-bound y))
                                  (- (lower-bound y)))))
    
    ;;;;;;;;;;;;;;2.9
    (define (width-interval x)
      (/ (- (upper-bound x) (lower-bound x)) 2))
    
    ;(width-interval (add-interval x y)) (1)
    ;(width-interval (sub-interval x y))  (2)
    ;(+ (width-interval x) (width-interval y)) (3)
    ;(- (width-interval x) (width-interval y)) (4)
    ;
    ;(1) (3)是等价的
    ;(width-interval (mul-interval x y)) (5)
    ;(* (width-interval x) (width-interval y)) (6)
    ;(5) (6) 不等价
    
    ;;;;;;;;;;;2.10
    (define (div-interval x y)
      (if (< (* (upper-bound y) (lower-bound y)) 0)
          (error "division interval isn't right")
          (mul-interval x
                        (make-interval (/ 1.0 (upper-bound y))
                                       (/ 1.0 (lower-bound y))))))
    
    ;;;;;;;;;2.11
    (define (mul-interval x y)
      (let ((xl (lower-bound x))
            (xu (upper-bound x))
            (yu (upper-bound y))
            (yl (lower-bound y)))
        (cond ((and (< xl 0) (< xu 0)) (cond ((and (< yl 0) (< yu 0))
                                              (make-interval
                                               (* xu yu) (* xl yl)))
                                              ((and (< yl 0) (> yu 0))
                                              (make-interval
                                               (* xl yu) (* xl yl)))
                                              ((and (> yl 0) (> yu 0))
                                              (make-interval
                                               (* xl yu) (* xu yl)))))
              ((and (< xl 0) (> xu 0)) (cond ((and (< yl 0) (< yu 0))
                                              (make-interval
                                               (* xu yl) (* xl yl)))
                                             ((and (< yl 0) (> yu 0))
                                              (make-interval
                                               (* xl yu) (* xu yu)))
                                             ((and (> yl 0) (> yu 0))
                                              (make-interval
                                               (* xl yu) (* xu yu)))))
              ((and (> xl 0) (> xu 0)) (cond ((and (< yl 0) (< yu 0))
                                              (make-interval
                                               (* xu yl) (* xl yu)))
                                             ((and (< yl 0) (> yu 0))
                                              (make-interval
                                               (* xu yl) (* xu yu)))
                                             ((and (> yl 0) (> yu 0))
    (make-interval (
    * xl yl) (* xu yu))))))) ;;;;;;;;;;;;;;;改成这种形式可能是因为当乘法代价比较高时 ;;;;;;;;;;;;;;;可以提高效率
    Yosoro
  • 相关阅读:
    jenkins(5): jenkins邮件报警配置
    Hive(二)—— 架构设计
    Flume(三) —— 断点续传 与 事务
    Flume(二) —— 自定义拦截器、Source、Sink
    Canal —— 基本概念及使用
    Kafka(五) —— Kafka源码本地调试
    Hadoop(五)—— HDFS NameNode、DataNode工作机制
    Cloudera-Manage —— 基本概念及使用
    【系统设计&解决方案】秒杀系统设计
    HBase(一) —— 基本概念及使用
  • 原文地址:https://www.cnblogs.com/tclan126/p/6379366.html
Copyright © 2011-2022 走看看