最大子段和问题的动态规划算法_第1页
最大子段和问题的动态规划算法_第2页
最大子段和问题的动态规划算法_第3页
最大子段和问题的动态规划算法_第4页
最大子段和问题的动态规划算法_第5页
已阅读5页,还剩4页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

三、求最大子段和

给定由n个整数(可能为负整数)组成的序列a1,a2,…,an,求该序列形如的子段和的最大值。当所有整数均为负整数时定义其最大子段和为0。依此定义,所求的最优值为:例如,当(a1,a2,a3,a4,a5,a6)=(-2,11,-4,13,-5,-2)时,最大子段和为:=20。最大子段和问题的简单算法用数组a[]存储给定的n个整数a1,a2,…,an。intMaxSum(intn,inta*,int&besti,int&bestj){intsum=0;

for(inti=1;i<=n;i++)

for(intj=i;j<=n;j++) {intthissum=0;

for(intk=i;k<=j;k++)thissum+=a[k]; if(thissum>sum)

{sum=thissum; besti=i; bestj=j;}}returnsum;}从这个算法的3个for循环可以看出它所需的计算时间是O(n3)事实上,如果我们注意到=则可将算法中的最后一个循环省去,避免重复计算,从而使算法得以改进。改进后的算法可描述为:intMaxSum(intn,int*a,int&besti,int&bestj){intsum=0;

for(inti=1;i<=n;i++) {intthissum=0;

for(intj=i;j<=n;j++) {thissum+=a[j]; if(thissum>sum){sum=thissum;besti=i;bestj=j;}}}returnsum;}改进后的算法只需要O(n2)的计算时间。上述改进是在算法设计技巧上的一个改进,能充分利用已经得到的结果,避免重复计算,节省了计算时间。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]的最大子段和的和。

例如,当(a1,a2,a3,a4,a5,a6)=(-2,11,-4,13,-5,-2)时,最大子段和为:Max{11,13,20}求最大子段和的分治算法如下:intMaxSubSum(int*a,intleft,intright){intsum=0;if(left==right)sum=a[left]>0?a[left]:0;else{intcenter=(left+right)/2;intleftsum=MaxSubSum(a,left,center);intrightsum=MaxSubSum(a,center+1,right);

ints1=0;intlefts=0;

for

(inti=center;i>=left;i--){lefts+=a[i];if(lefts>s1)s1=lefts;}

ints2=0;intrights=0;

for(inti=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;}returnsum;}分治算法的时间复杂性分析时间复杂度:得T(n)=O(nlogn)

3.最大子段和问题的动态规划算法(1)分析问题最优解的结构在对上述分治算法的分析中我们注意到,若记b[j]=,1≤j≤n,则所求最大子段和为:由b[j]的定义易知,

当b[j-1]>0时,b[j]=b[j-1]+a[j],

否则,b[j]=a[j]。(2)建立递归方程b[j]=max{b[j-1]+a[j],a[j]},1≤j≤n

最大子段和问题的动态规划算法----例:a[n+1]11-2-2-4-5130154326b[n+1]0015432601ij0sumbestibestj00jjjjjjjjjjjj-2121121122374201320245156求a=(-2,11,-4,13,-5,-2)的最大子段和。a[n+1]11-2-2-4-5130154326b[n+1]00154326jjjjjjjjjjjj-2117201315(3)计算最优值据此,可设计出求最大子段和的动态规划算法如下:intMaxSum(intn,int*a){intsum=0,b=0,i=0,besti=0,bestj=0;

for(intj=1;j<=n;j++) {if(b>0)b+=a[j]; else{b=a[j];i=j;}if(b>sum){sum=b;besti=i;bestj=j;}

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论