/*
动态转移方程:dp[i][j]=max(dp[i-1]+a[i], max(dp[t][j-1])+a[i]) (j-1<=t<i)
表示的是前i个数j个字段和的最大值是多少!
*/
1 #include<iostream>
#include<cstdio>
#include<cstring>
#define N 10000
using namespace std; int dp[N][N], num[N]; int main()
{
int n, m, i, j, k;
while(scanf("%d%d", &m, &n)!=EOF)
{
for(i=; i<=n; i++)
scanf("%d", &num[i]);
memset(dp, , sizeof(dp));
for(j=; j<=m; j++)
for(i=j; i<=n-m+j; i++)
if(i>j)
{
dp[i][j]=dp[i-][j]+num[i];
for(k=j-; k<i; k++)//可以用一个Max变量一直更新 j-1 到 i-1 的 最大值
dp[i][j]=max(dp[i][j], dp[k][j-]+num[i]);
}
else dp[i][j]=dp[i-][j-]+num[i];
int sum=-;
for(i=m; i<=n; i++)
if(dp[i][m]>sum)
sum=dp[i][m];
printf("%d\n", sum) ;
}
return ;
}
/*
时间上优化一下!
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#define N 1000010
using namespace std; __int64 dp[N][], num[N]; int main()
{
__int64 n, m, i, j, k, pos;
while(scanf("%I64d%I64d", &m, &n)!=EOF)
{
for(i=; i<=n; i++)
{
scanf("%I64d", &num[i]);
dp[i][]=dp[i][]=;
}
pos=;
for(j=; j<=m; j++)
{
dp[j][pos]=dp[j-][pos^]+num[j];
__int64 Max=dp[j-][pos^];
for(i=j+; i<=n-m+j; i++)
{
Max=max(Max, dp[i-][pos^]);//这一块直接将 k 的 for循环去掉
dp[i][pos]=max(dp[i-][pos], Max)+num[i];
}
pos^=;
}
pos^=;
__int64 sum=-;
for(i=m; i<=n; i++)
if(dp[i][pos]>sum)
sum=dp[i][pos];
printf("%I64d\n", sum) ;
}
return ;
}
 /*
内存上优化一下,一维数组求解!
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#define N 1000010
using namespace std; __int64 dp[N], num[N]; int main()
{
__int64 n, m, i, j, k, oldN;
__int64 maxN;//记录dp[k][j-1] (k>=j-1 && k<i) 只有num[i]自己属于第 j 段 所有情况的最大值!
while(scanf("%I64d%I64d", &m, &n)!=EOF)
{
for(i=; i<=n; i++){
scanf("%I64d", &num[i]);
dp[i]=;
}
for(j=; j<=m; j++)
{
maxN=max(dp[j-], dp[j]);// Max = max(dp[j-1][pos^1], dp[j][pos^1])
dp[j]=dp[j-]+num[j];
for(i=j+; i<=n-m+j; i++)
{
oldN=dp[i];// 记录 dp[i-1][pos^1]
dp[i]=max(maxN, dp[i-])+num[i] ;// dp[j][pos] = dp[j-1][pos^1] + num[j]
maxN=max(oldN, maxN);
}
}
__int64 sum=-;
for(i=m; i<=n; ++i)
if(dp[i]>sum)
sum=dp[i];
printf("%I64d\n", sum) ;
}
return ;
}


HDU 1024Max Sum Plus Plus(最大m字段和)的更多相关文章

  1. HDOJ(HDU).1258 Sum It Up (DFS)

    HDOJ(HDU).1258 Sum It Up (DFS) [从零开始DFS(6)] 点我挑战题目 从零开始DFS HDOJ.1342 Lotto [从零开始DFS(0)] - DFS思想与框架/双 ...

  2. 杭电1024Max Sum Plus Plus

    地址:http://acm.hdu.edu.cn/showproblem.php?pid=1024 题目: Problem Description Now I think you have got a ...

  3. MyBatis处理一行数据-MyBatis使用sum语句报错-MyBatis字段映射-遁地龙卷风

    第二版 (-1)写在前面 我用的是MyBatis 3.2.4 (0) 编程轶事 select sum(value) ,sum(value2)  from integral_list where  Me ...

  4. hdu 1258 Sum It Up(dfs+去重)

    题目大意: 给你一个总和(total)和一列(list)整数,共n个整数,要求用这些整数相加,使相加的结果等于total,找出所有不相同的拼凑方法. 例如,total = 4,n = 6,list = ...

  5. 数论 --- 费马小定理 + 快速幂 HDU 4704 Sum

    Sum Problem's Link:   http://acm.hdu.edu.cn/showproblem.php?pid=4704 Mean: 给定一个大整数N,求1到N中每个数的因式分解个数的 ...

  6. HDU 1231 最大连续子序列 &&HDU 1003Max Sum (区间dp问题)

    C - 最大连续子序列 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit ...

  7. HDU 4704 Sum (高精度+快速幂+费马小定理+二项式定理)

    Sum Time Limit:1000MS     Memory Limit:131072KB     64bit IO Format:%I64d & %I64u Submit Status  ...

  8. HDU 5776 sum (模拟)

    sum 题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5776 Description Given a sequence, you're asked ...

  9. hdu 5586 Sum 最大子段和

    Sum Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=5586 Desc ...

随机推荐

  1. 64位系统 IIS中应用程序池设置导致 访问数据库错误

    64 位操作系统不支持Microsoft OLE DB Provider for Jet驱动程序,也不支持更早的Microsoft Access Driver (*.mdb)方式连接.导致程序里面的数 ...

  2. CreateCompatibleDC 与 CreateCompatibleBitmap 小小结

    通常使用CreateCompatibleBitmap时候都会用到CreateCompatibleDC.而是用CreateCompatibleDC的目的不是为CreateCompatibleBitmap ...

  3. switch 的一些事

    switch后面的括号的表达式,其值得 “类型" 应为整数类型(包括字符类型). case后面跟一个常量或者常量表达式,

  4. 前台传参数时间类型不匹配:type 'java.lang.String' to required type 'java.util.Date' for property 'createDate'

    springMVC action接收参数: org.springframework.validation.BindException: org.springframework.validation.B ...

  5. MySQL数据库有外键约束时使用truncate命令的办法

    MySQL数据库操作中,Delete与Truncate两个命令都可以删除一个数据表中的全部数据,使用办法分别是: DELETE FROM t_question TRUNCATE TABLE t_que ...

  6. 将EnyimMemcached从.NET Core RC1升级至RC2

    .NET Core RC1时project.json中的配置如下: { "version": "3.2.4", "summary": &qu ...

  7. dijit样式定制(三)Button、RadioButton、CheckBox

    dijit.form.DropDownButton dijit的button中除了ComboButton使用table布局外,其他的button都是用span嵌套布局,下图中可看一下button的主要 ...

  8. Wix 安装部署教程(八) 自动生成XML小工具

    这个功能类似于Heat.exe,指定文件夹,生成对应的WIX标签.Winform做的,代码简单,生成的标签需要粘贴到对应的目录才能使用,并不是一步到位. 需要设定两个参数,一个是文件夹路径,一个是文件 ...

  9. 浅谈 SOLID 原则的具体使用

    SOLID 是面向对象设计5大重要原则的首字母缩写,当我们设计类和模块时,遵守 SOLID 原则可以让软件更加健壮和稳定.那么,什么是 SOLID 原则呢?本篇文章我将谈谈 SOLID 原则在软件开发 ...

  10. springmvc下js控制表单提交(表单提交前检验,提交后获取json返回值)

    这个问题我搞了四天,终于搞懂.因为对js很不熟悉.郁闷的是后台代码出错总可以设置断点调试,前端js代码出错只能通过浏览器提供一些运行数据来分析,很不习惯. 首先说下逻辑:这是一个注册功能,我希望,注册 ...