




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
计算机问题求解
–
论题2-3
分治法与递归MergesortRevisited问题1:这个算法究竟是如何“排”序的?5 2 4 7 1 3 2 65 2 4 71 3 2 6DivideDividefurther,until…conquer问题2:人的思维“分而治之”如何变为算法策略的呢?问题3:如何考虑分治算法的代价?递归代价与非递归代价导出递归式两次递归,理想情况下每次问题规模是原来的一半。非递归开销ncn
log
n确实比插入排序效率高。这里似乎假设n是2的整次幂,在我们涉及的大多数情况下,这不影响结果。问题4:书上的投资回报问题是怎样被转化为最大子数组问题的?Maximumsubarray简单的遍历所有可能的子序列MaxSum=0;
for(i=0;i<N;i++){ThisSum=0;
for(j=i;j<N;j++){
ThisSum+=A[j];if(ThisSum>MaxSum)MaxSum=ThisSum;}}returnMaxSum;thesequencei=0i=1i=2i=n-1jinO(n2)下面的过程遍历的顺序为:(0,0),(0,1),…,(0,n-1);(1,1),(1,2),…,(1,n-1),……(n-2,n-2),(n-2,n-1),(n-1,n-1)用分治法解最大子数组问题Part1Part2thesubwithlargestsummaybein:Part1Part2or:Part1Part2recursionThelargestistheresult问题5:跨中点的部分如何计算?非递归代价:常量递归,理想状况下问题规模是原来的一半。非递归代价:线性非递归代价:常量O(n
log
n)矩阵乘法:似乎非得
(n3)1个n阶方阵相乘的问题可以分解为8个n/2阶方阵相乘的子问题。仍然是立方复杂度问题6:决定上面的递归代价比较大的原因是什么?问题7:你能否描述Strassen方法的基本思想?复杂的组合为了减少一次乘法诸Si只需通过加减法计算这个算法曾经引起轰动问题8:你对于这个结果是否有感性认识?问题9:为什么降低子问题个数会导致复杂度的阶下降?递归树
T(size)nonrecursivecost对应于T(n)=T(n/2)+T(n/2)+n的递归树T(n)nT(n/4)n/4T(n/4)n/4T(n/4)n/4T(n/4)n/4T(n/2)n/2T(n/2)n/2对应于分治法的递归树方程divide-and-conquer:T(n)=aT(n/b)+f(n)Afterkthexpansion:T(n)=3T(
n/4)+(n2)cn2T(1)T(1)T(1)T(1)T(1)T(1)T(1)T(1)T(1)T(1)T(1)T(1)T(1)c((1/16)n)2c((1/16)n)2…………c(¼n)2c(¼n)2c(¼n)2log4ncn2…Total:
(n2)Note:c((1/16)n)2c((1/16)n)2c((1/16)n)2…………T(1)T(n)=aT(n/b)+f(n)f(n)T(1)T(1)T(1)T(1)T(1)T(1)T(1)T(1)T(1)T(1)T(1)T(1)T(1)f(n/b2)f(n/b2)f(n/b2)f(n/b2)f(n/b2)f(n/b2)f(n/b2)f(n/b2)f(n/b2)…………f(n/b)f(n/b)f(n/b)logbnf(n)…Note:aaTotal?…SolvingtheDivide-and-ConquerT(n)=aT(n/b)+f(n)作为一种典型的分治算法递归式:Letbase-casesoccuratdepthD(leaf),thenn/bD=1,thatisD=lg(n)/lg(b)LetthenumberofleavesofthetreebeL,thenL=aD,thatisL=a(lg(n)/lg(b)).Byalittlealgebra:L=nlg(a)/lg(b),lg(a)/lg(b)=logba因此,这个值决定了树的“胖”度。Divide-and-Conquer:theSolutionTherecursiontreehasdepthD=lg(n)/lg(c),sothereareaboutthatmanyrow-sums.The0throw-sumisf(n),thenonrecursivecostoftheroot.TheDthrow-sumis,assumingbasecasescost1,or(
)inanyevent.Thesolutionofdivide-and-conquerequationisthenon-recursivecostsofallnodesinthetree,whichisthesumoftherow-sums.SolutionbyRow-sums[LittleMasterTheorem]Row-sumsdecidethesolutionoftheequationfordivide-and-conquer:Increasinggeometricseries:T(n)
(nE)Constant:T(n)
(f(n)logn)Decreasinggeometricseries:T(n)
(f(n))Thiscanbegeneralizedtogetaresultnotusingexplicitlyrow-sums.MasterTheorem对简单的分治法解矩阵相乘,logba
=3。问题10:在比较两个函数大小时,是什么意思?Polynomiallylarger/smallerUsingMasterTheoremUsingMasterTheoremMaster定理的条件有空隙T(n)=2T(n/2)+nlgna=2,b=2,logba=1,f(n)=nlgnWehavef(n)=(n1),butno>0satisfiesf(n)=(n1+),sincelgngrowsslowerthatn
foranysmallpositive.So,case3doesn’tapply.However,neithercase2appli
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 软件测试中的质量控制与保证机制试题及答案
- 道路冷补修复材料试题及答案
- 计算机三级考试新趋势试题及答案
- 嵌入式系统调试技巧考题试题及答案
- 数据库存储过程撰写技巧试题及答案
- 通信设备专业高频信号处理维修考核试卷
- 四级软件测试工程师访问量提升试题及答案
- 基于MySQL的后台数据库管理技巧试题及答案
- 嵌入式系统的市场潜力分析试题及答案
- 敏捷实践下的测试反馈循环试题及答案
- 孩子心理成长中家长角色的科学定位
- 小学生反诈骗班会课件
- 《大气辐射学》课件
- 康养休闲旅游服务基础知识单选题及答案解析
- 新课标(水平三)体育与健康《篮球》大单元教学计划及配套教案(18课时)
- 解剖学公开课课件内分泌
- 银屑病临床病例讨论
- 【MOOC】工程经济学原理-东南大学 中国大学慕课MOOC答案
- 涉密人员审查备案登记表
- 2023-2024学年广东省深圳市深中共同体联考八年级(下)期中地理试卷
- 高层建筑汽车吊吊装作业方案
评论
0/150
提交评论