hdoj Max Sum Plus Plus(DP)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1024
题意:----最大M子段和问题
给定由 n个整数(可能为负整数)组成的序列a1,a2,a3,……,an,以及一个正整数 m,要求确定序列 a1,a2,a3,……,an的 m个不相交子段,
使这m个子段的总和达到最大,求出最大和。
思路:DP
用a数组表用示数据,dp[i][j]表示将前j个数划分成i个子段的和的最大值(a[j]包含在最后一个段中)。
则有状态转移方程:dp[i][j]=max(dp[i][j-1]+a[j] , dp[i-1][t]+a[j]),其中i-1<=t<=j-1。即将a[j]合并到最后一个段还是独立组成一个段。
这样的时间复杂度为O(m*n^2),空间复杂度为O(m*n),均比较大。
优化:在计算dp [i][j]时会花费大量时间计算dp[i-1][t] (i-1<=t<=j-1),如果进一步用dp的思想将dp[i-1][t]的值在之前的计算中存储起来,那么时间复杂度将只有O(m*n),那么可以用f[j-1]表示dp[i-1][t] (i-1<=t<=j-1),于是发现f[n] 我们始终用不上。在计算dp[i][j] 时需要f[j-1](此时的f[j-1]是i-1层的),在计算dp[i][j]的过程可以得到f[j](i层的),但不能马上赋给f[j],因为此时的f[j]存储的将前j个数据划分成i-1段的最大值,在计算dp[i][j+1]时需要,所以可以暂时存储在f[n]中,在计算完
dp[i][j+1]后之后再赋给f[j]。这样就省去了每次循环时计算dp[i-1][t]的时间。
同时我们会发现dp数组可以不需要了,可以用tmp临时表示dp[i][j]。这样就不需要dp这个耗空间巨大的数组了。
AC代码:
#include<bits/stdc++.h>
using namespace std; const int maxn=1e6+;
int n,m;
int a[maxn],f[maxn]; int dp(){
int tmp;
for(int i=;i<=m;i++){
tmp=;
for(int j=;j<=i;j++)
tmp+=a[j];
f[n]=tmp;
for(int j=i+;j<=n;j++){
tmp=max(tmp,f[j-])+a[j];
f[j-]=f[n];
f[n]=max(f[j-],tmp);
}
}
return f[n];
} int main(){
while(scanf("%d%d",&m,&n)!=EOF){
for(int i=;i<=n;i++)
scanf("%d",&a[i]),f[i]=;
printf("%d\n",dp());
}
return ;
}
参考:https://www.cnblogs.com/dongsheng/archive/2013/05/28/3104629.html
hdoj Max Sum Plus Plus(DP)的更多相关文章
- HDU 1024 Max Sum Plus Plus(dp)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1024 题目大意:有多组输入,每组一行整数,开头两个数字m,n,接着有n个数字.要求在这n个数字上,m块 ...
- HDU 1024:Max Sum Plus Plus(DP)
http://acm.hdu.edu.cn/showproblem.php?pid=1024 Max Sum Plus Plus Problem Description Now I think you ...
- HDU1024 Max Sum Plus Plus(dp)
链接:http://acm.hdu.edu.cn/showproblem.php?pid=1024 #include<iostream> #include<vector> #i ...
- HDU 1024 Max Sum Plus Plus (动态规划)
HDU 1024 Max Sum Plus Plus (动态规划) Description Now I think you have got an AC in Ignatius.L's "M ...
- HDU 1024 Max Sum Plus Plus(DP的简单优化)
Problem Description Now I think you have got an AC in Ignatius.L's "Max Sum" problem. To b ...
- HDU 1024:Max Sum Plus Plus(DP,最大m子段和)
Max Sum Plus Plus Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others ...
- Leetcode之动态规划(DP)专题-64. 最小路径和(Minimum Path Sum)
Leetcode之动态规划(DP)专题-64. 最小路径和(Minimum Path Sum) 给定一个包含非负整数的 m x n 网格,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小. ...
- Leetcode之动态规划(DP)专题-931. 下降路径最小和(Minimum Falling Path Sum)
Leetcode之动态规划(DP)专题-931. 下降路径最小和(Minimum Falling Path Sum) 给定一个方形整数数组 A,我们想要得到通过 A 的下降路径的最小和. 下降路径可以 ...
- Leetcode之动态规划(DP)专题-712. 两个字符串的最小ASCII删除和(Minimum ASCII Delete Sum for Two Strings)
Leetcode之动态规划(DP)专题-712. 两个字符串的最小ASCII删除和(Minimum ASCII Delete Sum for Two Strings) 给定两个字符串s1, s2,找到 ...
随机推荐
- Apache2.4.7 + php5 + mysql thinkphp
1. LAMP 的安装sudo apt-get install apache2 2.安装PHP sudo apt-get install libapache2-mod-php5 php5 php5- ...
- 数组比较大小的几种方法及math是方法
call apply bind 的区别? 解决函数内this的指向: 1.可以在函数外提前声明变量 一般情况下我们用 var _this/that=this 2.通过apply和call来修改函数 ...
- 1108 Finding Average (20 分)
1108 Finding Average (20 分) The basic task is simple: given N real numbers, you are supposed to calc ...
- javascript节点操作移出节点removeChild()
removeChild(a)是用来删除文档中的已有元素 参数a:要移出的节点 <div id="guoDiv"> <span>1</span> ...
- 第10课 struct 和 union 分析
1. struct的小秘密 (1)C语言中的struct可以看作变量的集合 (2)struct的问题——空结构体占用多的内存? [实例分析]空结构体的大小 #include <stdio.h&g ...
- 长沙雅礼中学集训-------------------day1(内含day0)
day0: 首先,请允许我吐槽一下: 1.那些一个人住一个标准房的人您们真的是#@**¥&%……#*()%……*()@Q$&. 2.感谢那些一个人住一个标准间的人,要不然我们也找不到这 ...
- ubuntu 18.04下svn的安装与基本命令
一.安装: apt-get install subversion 二.基本命令 1.将文件checkout到本地目录 svn checkout path(path是服务器 上的目录)例如:svn ch ...
- hive-hbase-handler方式导入hive表数据到hbase表中
Hive与HBase的整合功能的实现是利用两者本身对外的API接口互相进行通信,相互通信主要是依靠hive-hbase-handler.jar工具类 : hive-hbase-handler.jar在 ...
- 使用SharedPreferences存储数据
SharedPreferences把数据保存在指定名称的XML文件中,文件地址在/data/data/包名/Shared_Prefs/文件夹中,具体是通过map形式保存. 保存数据: SharedPr ...
- robot framework取出列表子元素
取出嵌套列表变量的子元素 ${list}型列表: ${list} = [["A1", "first"], ["A2", "seco ...