- 1、本文档共9页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
最大子段和问题的动态规划算法精选
三、求最大子段和 2.最大子段和问题的分治算法 从最大子段和问题的解的结构可以看出,它适合用分治法求解。 a[1:n]的最大子段和有三种情形: (1) a[1:n]的最大子段和与a[1:n/2]的最大子段和相同。 (2) a[1:n]的最大子段和与a[n/2+1:n]的最大子段和相同。 (3) a[1:n]的最大子段和为 , 且1≤i≤n/2, n/2+1≤j≤n。 其中(1)和(2)这两种情形可递归求得。 对于情形(3), a[n/2]与a[n/2+1]在最优子序列中,a[1:n]的最大子段和是a[1:n/2]的最大子段和与a[n/2+1:n]的最大子段和的和。 求最大子段和的分治算法如下: int MaxSubSum(int *a, int left, int right) { int sum =0; if (left==right) sum= a[left] 0?a[left]:0; else { int center = (left+right)/2; int leftsum = MaxSubSum(a, left, center); int rightsum = MaxSubSum(a, center+1, right ); int s1 =0; int lefts =0; for (int i=center; i=left; i--) { lefts += a[i]; if (lefts s1) s1= lefts; } int s2 =0; int rights =0; for (int i=center+1; i=right; i++) { rights += a[i]; if (rights s2) s2= rights; } sum = s1+s2; if (sum leftsum) sum = leftsum; if (sum rightsum) sum = rightsum; } return sum; } 分治算法的时间复杂性分析 时间复杂度: 得T(n)=O(nlog n) 3. 最大子段和问题的动态规划算法 (1)分析问题最优解的结构 在对上述分治算法的分析中我们注意到,若记 b[j]= , 1≤j≤n,则所求最大子段和为: * 给定由n个整数(可能为负整数)组成的序列a1, a2,…, an, 求该序列形如 的子段和的最大值。当所有整数均为负整数时定义其最大子段和为0。依此定义,所求的最优值为: 例如, 当(a1,a2,a3,a4 ,a5,a6) = (-2,11,-4,13,-5,-2)时,最大子段和为: = 20。 最大子段和问题的简单算法 用数组a[ ]存储给定的n个整数a1, a2,…, an。 int MaxSum(int n, int a*, int besti, int bestj) { int sum=0; for (int i=1; i=n; i++) for (int j=i; j=n; j++) { int thissum=0; for (int k=i; k=j; k++) thissum+=a[k]; if (thissumsum) { sum= thissum; besti= i; bestj=j; } } return sum; } 从这个算法的3个for循环可以看出它所需的计算时间是O(n3)事实上,如果我们注意到 = 则可将算法中的最后一个循环省去,避免重复计算,从而使算法得以改进。改进后的算法可描述为: int MaxSum(int n, int *a, int besti, int bestj) { int sum=0; for (int i=1; i=n; i++) { int thissum=0; for (int j=i; j=n; j++) { thissum += a[j]; if (thissumsum)
您可能关注的文档
最近下载
- 山东职业学院档案管理.pdf VIP
- 冀教版小学数学四年级下册【全册】课时练+单元测试卷(含答案).pdf VIP
- DB11T 214-2016 居住区绿地设计规范.pdf VIP
- 国家开放大学电大本科《C语言程序设计》期末试题标准题库及答案(试卷号:1253).pdf VIP
- 天津专用2025届高考化学一轮复习考点规范练37生命中的基础有机化合物有机合成含解析.docx VIP
- 爆破工程技术人员取证培训初级D设计题真题参考答案.pdf VIP
- 利安隆(珠海)新材料有限公司年产5.15万吨高分子材料抗老化助剂混配、造粒项目环评报告表.pdf VIP
- 医生三基三严知识题库(附答案).docx VIP
- 2025年【N1叉车司机】考试及N1叉车司机考试题库(含答案).docx
- 未成年人防性侵安全教育.pptx VIP
文档评论(0)