- 1、本文档共41页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
天津科技大学算法设计与分析 第5章 减治法
算法设计与分析--减治法 具有11个结点的判定树 问题的解决是经过一系列比较和判断,可以用判定树来描述这个判定过程。 考虑不是把硬币分成两组,而是分成三组,前两组有 组硬币,其余的硬币作为第三组,将前两组硬币放到天平上,如果他们的重量相同,则假币一定在第三组中,用同样的方法对第三组进行处理;如果前两组的重量不同,则假币一定在较轻的那一组中,用同样的方法对较轻的那组硬币进行处理。显然这个算法存在递推式: 算法5.8——淘汰赛冠军问题 string Game(string r[ ], int n) { i=n; while (i1) { i=i/2; for (j=0; ji; j++) if (Comp(r[j+i], r[j])) r[j]=r[j+i]; } return r[0]; } 因为n=2k,所以,外层的while循环共执行k次,在每一次执行时,内层的for循环的执行次数分别是n/2,n/4,…,1,而函数comp可以在常数时间内完成,因此,算法5.8的执行时间为: 5.4.2 假币问题 在n枚外观相同的硬币中,有一枚是假币,并且已知假币较轻。可以通过一架天平来任意比较两组硬币,从而得知两组硬币的重量是否相同,或者哪一组更轻一些,但不知道轻多少,假币问题是要求设计一个高效的算法来检测出这枚假币。 解决这个问题的最自然的想法就是一分为二,也就是把硬币分成两组。把n枚硬币分成两组,每组有 枚硬币,如果n为奇数,就留下一枚硬币,然后把两组硬币分别放到天平的两端。 如果两组硬币的重量相同,那么留下的硬币就是假币;否则,用同样的方法对较轻的那组硬币进行同样的处理,假币一定在较轻的那组里。 在假币问题中,每次用天平比较后,只需解决一个规模减半的问题,所以,它属于一个减治算法。该算法在最坏情况下的时间性能有这样一个递推式: 应用扩展递归技术求解这个递推式,得到T(n)=O(log2n)。 这个递推式的解是T(n)=O(log3n)。 * 第5章 减治法 5.1 减治法的设计思想 5.2 查找问题中的减治法 5.3 排序问题中的减治法 5.4 组合问题中的减治法 5.1 减治法的设计思想 规模为n的原问题的解与较小规模(通常是n/2)的子问题的解之间具有关系: (1)原问题的解只存在于其中一个较小规模的子问题中; (2)原问题的解与其中一个较小规模的解之间存在某种对应关系。 由于原问题的解与较小规模的子问题的解之间存在这种关系,所以,只需求解其中一个较小规模的子问题就可以得到原问题的解。 子问题 的规模是n/2 子问题的解 原问题的解 原问题 的规模是n 减治法的设计思想 例:计算an的值,应用减治技术得到如下计算方法: 应用分治法得到an的计算方法是: O (log2n) O (nlog2n) ? ? ? í ì ′ = = - 且是奇数 且是偶数 1 ) ( 1 ) ( 1 2 2 ) 1 ( 2 2 n a a n a n a a n n n 应用减治法处理问题的效率一般是O(log2n)数量级。 减治法只对一个子问题求解,并且不需要进行解的合并。应用减治法(例如减半法)得到的算法通常具有如下递推式: 5.2 查找问题中的减治法 5.2.1 折半查找 5.2.2 二叉查找树 基本思想:在有序表中,取中间记录作为比较对象,若给定值与中间记录的关键码相等,则查找成功;若给定值小于中间记录的关键码,则在中间记录的左半区继续查找;若给定值大于中间记录的关键码,则在中间记录的右半区继续查找。不断重复上述过程,直到查找成功,或所查找的区域无记录,查找失败。 5.2.1 折半查找 [ r1 … … … rmid-1 ] rmid [ rmid+1 … … … rn ] (mid=(1+n)/2) 如果krmid查找这里 如果krmid查找这里 k 例:查找值为14的记录的过程: 0 1 2 3 4 5 6 7 8 9 10 11
您可能关注的文档
- 大学毕业论文答辩PPT范文_1764785260.ppt
- 大学毕业论文答辩PPT范文_1917625173.ppt
- 大学生与违法犯罪41.ppt
- 大学生人际交往与恋爱心理ppt模版课件.ppt
- 大学生创业-护理事务所企划案展示.ppt
- 大学生创业之案例分析(精选).ppt
- 大学生创新项目模板3-国产手机国际化战略分析—以华为.ppt
- 大学生如何谈恋爱(PPT-41).ppt
- 大学生对恋爱问题的看法(19P).ppt
- 大学生就业法律指导的思考与实践.ppt
- 抢分秘籍10 带电粒子电场中的直线运动、偏转和交变电电场中的应用(三大题型)(原卷版)-2025年高考物理冲刺抢押秘籍.pdf
- 抢分秘籍11 带电粒子在组合场、叠加场中的运动(五大题型)(解析版)-2025年高考物理冲刺抢押秘籍.pdf
- 抢分秘籍11 带电粒子在组合场、叠加场中的运动(五大题型)(原卷版)-2025年高考物理冲刺抢押秘籍.pdf
- 抢分秘籍12 电磁感应中的电路与图像问题(二大题型)(解析版) -2025年高考物理冲刺抢押秘籍.pdf
- 抢分秘籍12 电磁感应中的电路与图像问题(二大题型)(原卷版)-2025年高考物理冲刺抢押秘籍.pdf
- 抢分秘籍14 热力学定律与气体实验定律综合应用(五大题型)(解析版)-2025年高考物理冲刺抢押秘籍.pdf
- 抢分秘籍13 电磁感应中的动力学、能量和动量问题(三大题型)(原卷版)-2025年高考物理冲刺抢押秘籍.pdf
- 抢分秘籍14 热力学定律与气体实验定律综合应用(五大题型)(原卷版)-2025年高考物理冲刺抢押秘籍.pdf
- 抢分秘籍16 振动图像与波动图像的综合应用(三大题型)(解析版)-2025年高考物理冲刺抢押秘籍.pdf
- 抢分秘籍15 光的折射、全反射的综合应用(二大题型)(解析版)-2025年高考物理冲刺抢押秘籍.pdf
文档评论(0)