版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
三、求最大子段和
给定由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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 二零二五年度员工节假日旅游借款协议书3篇
- 《扑克牌自制糖果篮》课件
- 创伤患者的一般医疗护理课件
- 二零二五年度家庭医生签约服务及健康档案管理合同范本3篇
- 品牌销售代理协议书(2篇)
- 二零二五年度房产指标项目并购重组合同3篇
- 2025班主任师徒结对教育创新人才培养合作协议2篇
- 二零二五年度房屋买卖补偿与土地租赁合同3篇
- 二零二五年度10kv配电工程电力设施建设合同
- 报名表的模板
- 零碳智慧园区解决方案
- 2025年林权抵押合同范本
- 2024年北师大版四年级数学上学期学业水平测试 期末卷(含答案)
- 2024年高考物理一轮复习讲义(新人教版):第七章动量守恒定律
- 浙江省宁波市慈溪市2023-2024学年高三上学期语文期末测试试卷
- 草学类专业生涯发展展示
- 法理学课件马工程
- 《玉米种植技术》课件
- 第47届世界技能大赛江苏省选拔赛计算机软件测试项目技术工作文件
- 2023年湖北省公务员录用考试《行测》答案解析
- M200a电路分析(电源、蓝牙、FM)
评论
0/150
提交评论