SICP_Python版第二章

数据结构的过程性表示:

2.5 :证明很容易,假设存在a<0或者b<0,则
Pair(a,b)=2a3|b|3b2|a|

因为gcd(2,3)=1,所以Pair(a,b)不能继续约分,所以Pair(a,b)不是整数。因此可以只用非负数来表示序对。

表示的代码如下:

def make_pair(a,b):
    def dispatch(m):
        if m==0:
            return a
        else:return b
    return dispatch
def getitem_pair(p,i):
    return p(i)
def make_integer(a,b):
    return make_pair(a,b)
def get_a(n):
    return n(0)
def  get_b(n):
    return n(1)
def mul(n1,n2):
    a1,a2 = get_a(n1),get_a(n2)
    b1,b2 = get_b(n1),get_b(n2)
    return make_pair(a1+a2,b1+b2)
def div(n1,n2):
    a1,a2 = get_a(n1),get_a(n2)
    b1,b2 = get_b(n1),get_b(n2)
    return make_pair(a1-a2,b1-b2)
def str_integer(n):
    return '2^{0}*3^{1}'.format(get_a(n),get_b(n))
print(str_integer(mul(make_pair(3,2),make_pair(2,3))))

2.72.8:


def add_interval(a,b):
    return make_interval(lower_bound(a)+lower_bound(b),upper_bound(a)+upper_bound(b))
def sub_inerval(a,b):
    return make_interval(lower_bound(a)-upper_bound(b),upper_bound(a)-lower_bound(b))
def mul_interval(a,b):
    l1,l2,u1,u2 = lower_bound(a),lower_bound(b),upper_bound(a),upper_bound(b)
    p1,p2,p3,p4 = l1*l2,l1*u2,u1*l2,u1*u2
    return make_interval(min([p1,p2,p3,p4]),max([p1,p2,p3,p4]))
def div_interval(a,b):
    return mul_interval(a,make_interval(1/upper_bound(b),1/lower_bound(b)))
def make_interval(l,u):
    return (l,u)
def lower_bound(m):
    return getitem(m,0)
def upper_bound(m):
    return getitem(m,1)
def str_interval(m):
    return '[{0},{1}]'.format(lower_bound(m),upper_bound(m))
x,y = make_interval(-1,2),make_interval(4,6)
print(add_interval(x,y),mul_interval(x,y),div_interval(x,y),sub_inerval(x,y))

2.9(a) :关于区间宽度,对于加法和减法,组合区间的宽度是关于两个区间宽度的函数:

W(add(a,b))=W(a)+W(b)=W(sub(a,b))....(1)

(b) :对于乘法和除法,则不满足函数关系:显然,当存在负数的时候,它可能满足几种关于两个宽度的关系式。如(-1,3),(4,6)

2.100

def div_interval(a,b):
    assert(lower_bound(b)*upper_bound(b) > 0)
    return mul_interval(a,make_interval(1/upper_bound(b),1/lower_bound(b)))

2.11,,

思路就是一个区间有三种情况,然后3*3=9,当然写起来很是麻烦…..

def mul_interval(a,b):
    def condition(l,u):
        if l<0 and u<0:return 0
        elif l*u <=0:return 1
        return 2
    l1,l2,u1,u2 = lower_bound(a),lower_bound(b),upper_bound(a),upper_bound(b)
    index = condition(l1,u1)+condition(l2,u2)*3
    if index == 0:return make_interval(u1*u2,l1*l2)
    elif index==1:return make_interval(u1*l2,l1*l2)
    elif index==2:return make_interval(u1*l1,l1*u2)
    elif index==3:return make_interval(u2*l2,l2*u1)
    elif index==4:return make_interval(min(l1*u2,l2*u1),max(l1*l2,u1*u2))#both span zero
    elif index==5:return make_interval(u1*l2,u2*l2)
    elif index==6:return make_interval(l1*u2,l2*u1)
    elif index==7:return make_interval(l1*u2,u1*u2)
    else:return make_interval(l1*l2,u1*u2)

2.12

def make_center_percent(a,b):
    return (a,b)
def center(m):
    return getitem(m,0)
def percent(m):
    return getitem(m,1)
def error(m):
    return center(m)*percent(m)/100

2.13

:X=[ae1,a+e1],Y=[be2,b+e2]

XY=[abae2be1+e1e2,ab+ae2+be1+e1e2]

e=ae2+be1,c=ab+e1e2==>

ec=ae2+be1ab+e1e2=p1+p21+p1p2=p1+p2(while....p1,p2<<1)(p1=e1a,p2=e2b)

2.142.16 :

简单的讲A/A!=1,因为我们的代码引入了不必要的不确定量,需要想办法确定每一个区间的身份。。。。这个超出了我的能力范围。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
"SICP中文"是指计算机科学经典教材《Structure and Interpretation of Computer Programs》(计算机程序的构造和解释)的中文翻译PDF。这本教材由麻省理工学院的Harold Abelson和Gerald Jay Sussman等人编写,是计算机科学领域中一本重要的教材。 "SICP中文PDF"提供了更方便的学习方式。无论是学生、程序员还是计算机科学爱好者,都可以在任何时候通过电子设备访问和学习这本教材。使用PDF格式的好处是可以在不同的平台上都能打开和阅读,而不受限于特定的操作系统或设备。 通过"SICP中文PDF",读者可以学习计算机科学的基本原理和概念,如过程、数据抽象、递归、高阶函数、并发等。这本教材以Scheme语言为示例,帮助读者理解计算机程序的结构、设计和解释。通过逐步的案例和练习,读者可以锻炼解决问题和编写高质量代码的能力。 "SICP中文PDF"也提供了沟通和讨论的平台。读者可以通过在线社群或论坛,与其他人分享学习心得、解答疑问和参与讨论。这为读者提供了一个学习交流的机会,促进了学习者之间的互动和共同成长。 总之,"SICP中文PDF"是一本经典的计算机科学教材的中文翻译本,使得更多的读者可以方便地学习和掌握其中的知识。无论是对于计算机科学专业的学生还是对计算机科学感兴趣的人,这本教材都是一本很好的参考书,并提供了丰富的实例和练习,让读者深入理解计算机程序的核心概念和设计原则。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值