1.最大字段和问题

求一个序列最大连续子序列之和。

例如序列[-1,-2,-3,4,5,-6]的最大子段和为4 + 5 = 9。

①枚举法

int MaxSum(int n,int *a){
int sum = -0x3f3f3f3f;
for(int i=;i<n;i++){
int b = ;
for(int j=i;j<n;j++){
b += a[j];
sum = b > sum ? b : sum;
}
}
return sum;
}

②动态规划

解题思路:

第一步:设b[ j ] 为 1到 j 的最大连续子序列之和。

第二步:因为b[ j ] 为以a[ j ]结尾的最大连续子序列之和,因此有两种可能

  1.b[ j ] = a[ j ]

  2.b[ j ] = b[ j - 1 ] + a[ j ]

因此我们可以得到递推方程,

b[ j ] = max{ a[ j ], b[ j  - 1] + a[ j ] } = max { 0 , b[ j - 1 ]} + a[ j ]

int MaxSum(int n,int *a){
int sum = -0x3f3f3f3f, b = ;
for(int i=; i<n; i++){
if(b>=)
b+=a[i];
else
b=a[i];
if(b>sum)
sum = b;
}
return sum;
}

2.引申:两个连续序列的最大字段和问题

求两个等长的序列的最大重叠连续子序列之和

例,第一个序列为[-1,-2,-3,4,5,-6],第二个序列为[1,2,4,4,5,-6],则 MAX = ( 4 + 5) + (4 + 5) = 19

2与1的区别在于,原本只有一个序列,现在变成两个,但是求的是最大重叠连序列之和,所以可以将两个序列加起来变成一个序列。

①枚举法

②动态规划

解题思路:

设b[ j ] 为 1到 j 的最大重叠连续子序列之和。

若b[ j - 1 ] >= 0 ,

  则 b[ j ] = b [ j - 1 ] + a[ 0 ][ j ] +  a[ 1 ][ j ];

  否则 b[ j ] = a[ 0 ][ j ] +  a[ 1 ][ j ]

int MaxSum(int n,int (*a)[]){
int sum = -0x3f3f3f3f, b = ;
for(int i=; i<n; i++){
if(b>=){
b+=a[][i];
b+=a[][i];
}
else{
b=a[][i];
b+=a[][i];
}
if(b>sum)
sum = b;
}
return sum;
}

3.最大子矩阵之和

给定矩阵A,求其子矩阵各元素之和的最值

若将矩阵的行看作是一个个的连续序列,则与2问题不同的是,

  第一,可能不只一个连续序列(矩阵的行)相加,

  第二,需要枚举子矩阵的初始行R0,和结束行R1

①枚举法

②动态规划

//求 r0行到r1行 第i列元素的和
int sum_r(int r0, int r1, int i){
int sum = ;
for(int r=r0;r<=r1;r++)
sum += a[r][i];
return sum;
}
//求最大子矩阵和
int MaxSum(){
int sum = -0x3f3f3f3f;
for(int r0=;r0<m;r0++){//枚举初始行
for(int r1=r0;r1<m;r1++){//枚举结束行
int b = ;
for(int i=; i<n; i++){//这个循环使用问题1中的算法
if(b>=)
b+=sum_r(r0,r1,i);//第r0行到第r1行 第i列元素和
else
b=sum_r(r0,r1,i); sum = sum > b? sum : b;
}
}
}
return sum;
}

我们能够注意到,上面的程序,需要我们写一个计算第r0行到第r1行第i列的元素和的函数sum_r( ),但是我们需要频繁调用这个函数,可以用一个数组来记录计算结果,这一步可以在我们读入数据的时候进行。

专门建立一个二维数组,col [ i ][ j ],记录第 i 列,前 j 个元素的和。

所以,MaxSum函数中,b += sum_r(r0, r1, i ),可以替换成

b += col[ i ][ r1 ] - col[ i ][ r0 - 1 ]

最终代码

int MaxSum(){
int sum = -0x3f3f3f3f;
for(int r0=;r0<m;r0++){
for(int r1=r0;r1<m;r1++){
int b = ;
for(int i=; i<n; i++){
if(b>=)
b+=col[i][r1] - col[i][r0 - ];
else
b=col[i][r1] - col[i][r0 - ]; sum = sum > b? sum : b;
}
}
}
return sum;
}

 4.最大m字段和问题

【动态规划】最大连续子序列和,最大子矩阵和,最大m子段和的更多相关文章

  1. HDU 1081 To the Max 最大子矩阵(动态规划求最大连续子序列和)

    Description Given a two-dimensional array of positive and negative integers, a sub-rectangle is any ...

  2. hdu1231最大连续子序列(动态规划)

    最大连续子序列 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Sub ...

  3. 动态规划:最大连续子序列乘积 分类: c/c++ 算法 2014-09-30 17:03 656人阅读 评论(0) 收藏

    题目描述: 给定一个浮点数序列(可能有正数.0和负数),求出一个最大的连续子序列乘积. 分析:若暴力求解,需要O(n^3)时间,太低效,故使用动态规划. 设data[i]:第i个数据,dp[i]:以第 ...

  4. 动态规划(Dynamic Programming, DP)---- 最大连续子序列和

    动态规划(Dynamic Programming, DP)是一种用来解决一类最优化问题的算法思想,简单来使,动态规划是将一个复杂的问题分解成若干个子问题,或者说若干个阶段,下一个阶段通过上一个阶段的结 ...

  5. 九度OJ 1501 最大连续子序列乘积 -- 动态规划

    题目地址:http://ac.jobdu.com/problem.php?pid=1501 题目描述: 给定一个浮点数序列(可能有正数.0和负数),求出一个最大的连续子序列乘积. 输入: 输入可能包含 ...

  6. 动态规划 HDU1231-------最大连续子序列

    Problem Description 给定K个整数的序列{ N1, N2, ..., NK },其任意连续子序列可表示为{ Ni, Ni+1, ..., Nj },其中 1 <= i < ...

  7. HDU 1231 最大连续子序列 (动态规划)

    最大连续子序列 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Sub ...

  8. UVa 108 - Maximum Sum(最大连续子序列)

    题目来源:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=3&pa ...

  9. dp经典问题-最大连续子序列和 hdu1003

    题目描述: 这道题我先后做过三遍,结果每一遍都没有做出来.今天再仔仔细细的研究了一下,才发现用动态规划更好理解. 关于求最大连续子序列和的博文转载如下:https://www.cnblogs.com/ ...

随机推荐

  1. 在table表格中实现圆角效果

    在table中设置border-radius发现不起作用,网上查找了一番,原因是border-collapse:collapse和border-radius不兼容. 设计图效果 代码实现效果: < ...

  2. 将1~n个整数按照字典序进行排序

    题意:给定一个整数n,给定一个整数k,将1~n个整数按字典顺序进行排序,返回排序后第k个元素. 题目链接:HDU6468 多组输入,T<=100,n<=1e6 分析:这个题和之前做的模拟出 ...

  3. Java中Annotation用法

    其他还可以参考的地址 https://www.cnblogs.com/skywang12345/p/3344137.html Annotation Annotation其实是代码里的特殊标记,这些标记 ...

  4. Vue-- 监听路由变化,数据无法更新?

    之前写的Vue项目,有个问题困扰了好久.新闻板块有推荐.精华.最新等几个Tab,设想通过切换Tab,改变路由参数(get/news/:tab)去获取对应数据,然后渲染到页面(用的是同一套组件),问题来 ...

  5. 20175227张雪莹 2018-2019-2 《Java程序设计》第五周学习总结

    20175227张雪莹 2018-2019-2 <Java程序设计>第五周学习总结 教材学习内容总结 第六章接口与实现 接口 接口体中所有的常量访问权限一定是public和static(可 ...

  6. wonder vscode plugins

    ├─ .obsolete├─ .wlck├─ .wtid├─ 1194979849.code-snippets-0.1.18├─ abeyuhang.vscode-lesslint-0.0.1├─ a ...

  7. day08_python_1124

    01 昨日内容回顾 文件操作 文件操作的流程: 1,打开文件创建文件句柄. 2,对文件句柄进行操作. 3,关闭文件句柄. 读, r r+ rb r+b read() 全部读取 read(n) 读取一部 ...

  8. js splice函数 数组增加,替换,删除

    splice函数参数介绍: 第一个参数: 对于数数组的操作起始位置. 第二个参数: 从第一个参数开始,删除数组中的个数. 从第三个参数之后所有参数(如果有):执行完第二步之后,都插入到第一个参数的起始 ...

  9. ui学习心得

    软工课上我分配的任务是界面设计,但是对于初期一个ps从没接触的人来说我觉得还是有点困难,所以要从头学起.  PS的功能是什么呢?对于业余爱好者来说,主要还是做一些简单的处理照片.绘图.设计一些皮肤等, ...

  10. redis缓存工具类

    import org.springframework.beans.factory.annotation.Autowired; import org.springframework.data.redis ...