ImageVerifierCode 换一换
格式:DOC , 页数:4 ,大小:29KB ,
资源ID:6259946      下载积分:10 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.docduoduo.com/d-6259946.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(算法作业-3.doc)为本站会员(myw993772)主动上传,道客多多仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知道客多多(发送邮件至docduoduo@163.com或直接QQ联系客服),我们立即给予删除!

算法作业-3.doc

1、1.证明 graham-scan 的正确性 2.优化 matrix-chain-orderPrint-optimal-parens,并构建优化三角剖分解如果在一个Q3 的点集 Q 上运行 graham-scan,则在过程终止时,栈 S 从底部到顶部包含了按逆时针方向排列在 CH(Q)中的各个顶点。证明:我们有点序列。对 i=2,3,m,定义一个点子集 Qi=p0,p1,pi。Q-Qm 中的点是那些被删除的点,因为它们与 Qm 中的某个点相对于 p0 的极角相同;这些点不在 CH(Q)中,因而 CH(Qm)=CH(Q) 。于是,只要证明当 graham-scan 终止时,栈 S 中包含了 CH(

2、Qm)的顶点,且这些顶点是按照逆时针从底部自顶部在栈中排列的。注意,正如 p0,p1 和 pm 是 CH(Q)中的顶点一样,p0,p1 和 pi 也是 CH(Qi)中的顶点。用循环不变式:初始化:在首次进入循环时,这个循环不变式得到保持,因为此时栈 S 中恰包含了 Q2=Qi-1 中的顶点,这三个顶点的集合形成了它们各自的凸包。此外,它们按逆时针排列,从底至顶地出现在栈 S 中。保持:进行 for 循环的一层迭代后,栈 S 顶上的点为 pi-1,它是在上一次迭代最后被压入栈的。设第 1011 行中 while 循环执行后,第 12 行将 pi 压入栈之前,栈 S 顶部的点为 pj。设 pk 为

3、栈 S 中紧靠 pj 之下的点。在 pi 成为栈顶且尚未将 pi 压入栈时,栈 S 中包含了与 for 循环的第 j 次迭代后一样的点。因此,根据循环不变式,在该时刻,栈 S 中恰包含了 CH(Qi)中的顶点,它们按逆时针自底向上地出现在栈中。我们继续关注单 pi 被压入栈之前的这一时刻。我们已经知道,pi相对于 p0 的极角大于 pj 的极角并且角 pkpjpi 是左转的。由于 S 恰包含了 CH(Qj)中顶点,因此,一旦压入 pi,栈 S 中恰包含了CH(Qjpi)中的顶点,并且这些点仍然按逆时针顺序自底向上地出现在栈中。考虑任意一个在 for 循环的第 i 次迭代中被弹出的点 pt,设

4、pr 和pt 被弹出时栈 S 中紧靠在 pt 下面的点。角 prptpi 所做的是非左转向,而 pt 相对于 p0 的极角大于 pr 的极角,pt 必定在由 p0,pr 和pi 构成的三角形内部,或者在这个三角形的某条边上。显然,由于pt 在一个由 Qi 的其他三个点构成的三角形内部,故不可能是CH(Qi)的一个顶点。所以:CH(Qi-pt)=CH(Qi)设 pi 为 for 循环的第 i 次迭代中弹出点的集合。由于上式适合 pi中所有点,故可以用它来反复说明 CH(Qi-pi)=CH(Qi) 。但是,Qi-pi=Qjpi,故 CH(Qjpi)= CH(Qi-pi)=CH(Qi)终止:当循环终

5、止时,有 i=m+1,因而,循环不变式意味着栈 S 中恰包含了 CH(Qm)中按逆时针顺序从栈底向上排列的顶点。执行第一行的代码需要时间 (n) ,应用归并排序或堆排序对极角进行排序,用叉积方法对极角进行比较,执行第 2 行代码所需要的时间为 O(nlgn) 。第 58 行代码执行时间为 O(1) 。因为 mn-1,所以第 912for 循环至多执行 n-3 次,因为 push 的时间为 O(1) ,故,除执行 while 时间,for 用时 O(n) 。While 循环时间为 O(n) 。对 i=0,1,m 每个点 pi 压入栈一次,执行 push 至多与 pop 一样。至少有三个顶点不会从

6、栈中弹出,所以事实上总共至多执行 m-2 次迭代。由于第 10 行的测试用时 O(1)每次调用 pop 所需时间 O(1),且 mn-1,所以 while 用时 O(n) ,故 graham-scan 用时 O(nlgn) 。2.Optimal-polygon-triangulation(p)nlength(p)-1for i1 to ndo ti,j 0for 12 to n dofor i1 to n-1+1 doji+1-1ti,j for ki to j-1 doqti,k+tk+1,j+W(i-1,k,j)if qi+1then print-optimal-parens(s.i,si,j)print Vi-1Vsi,j,Vsi,jVjprint-optimal-parens(s,si,j+1.j)return

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报