HDU 1024Max Sum Plus Plus(最大m字段和)
/*
动态转移方程: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字段和)的更多相关文章
- HDOJ(HDU).1258 Sum It Up (DFS)
HDOJ(HDU).1258 Sum It Up (DFS) [从零开始DFS(6)] 点我挑战题目 从零开始DFS HDOJ.1342 Lotto [从零开始DFS(0)] - DFS思想与框架/双 ...
- 杭电1024Max Sum Plus Plus
地址:http://acm.hdu.edu.cn/showproblem.php?pid=1024 题目: Problem Description Now I think you have got a ...
- MyBatis处理一行数据-MyBatis使用sum语句报错-MyBatis字段映射-遁地龙卷风
第二版 (-1)写在前面 我用的是MyBatis 3.2.4 (0) 编程轶事 select sum(value) ,sum(value2) from integral_list where Me ...
- hdu 1258 Sum It Up(dfs+去重)
题目大意: 给你一个总和(total)和一列(list)整数,共n个整数,要求用这些整数相加,使相加的结果等于total,找出所有不相同的拼凑方法. 例如,total = 4,n = 6,list = ...
- 数论 --- 费马小定理 + 快速幂 HDU 4704 Sum
Sum Problem's Link: http://acm.hdu.edu.cn/showproblem.php?pid=4704 Mean: 给定一个大整数N,求1到N中每个数的因式分解个数的 ...
- HDU 1231 最大连续子序列 &&HDU 1003Max Sum (区间dp问题)
C - 最大连续子序列 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Submit ...
- HDU 4704 Sum (高精度+快速幂+费马小定理+二项式定理)
Sum Time Limit:1000MS Memory Limit:131072KB 64bit IO Format:%I64d & %I64u Submit Status ...
- HDU 5776 sum (模拟)
sum 题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5776 Description Given a sequence, you're asked ...
- hdu 5586 Sum 最大子段和
Sum Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=5586 Desc ...
随机推荐
- Android PullToZoomListView实现放大回弹效果
另外一个相同项目的地址https://github.com/Frank-Zhu/PullZoomView 转自http://blog.csdn.net/wangjinyu501/article/det ...
- 练习ajax的时候出现这个问题 还没解决
VM601:1 Uncaught SyntaxError: Unexpected end of JSON input 应该怎么办呢
- 使用F#来实现哈夫曼编码吧
最近算法课要求实现哈夫曼编码,由于前面的问题都是使用了F#来解决,偶然换成C#也十分古怪,报告也不好看,风格差太多.一开始是打算把C#版本的哈夫曼编码换用F#来写,结果写到一半就觉得日了狗了...毕竟 ...
- 软件工程day7
参与组内讨论,关于新功能“吐槽墙”的UI设计,小组决定使用TabControl控件实施. 于周末几天自己使用PS学习临摹了一些程序的icon,完成度不高. 鉴于正在参与开发的软件为“工具性”+“微社交 ...
- 算法:Astar寻路算法改进,双向A*寻路算法
早前写了一篇关于A*算法的文章:<算法:Astar寻路算法改进> 最近在写个js的UI框架,顺便实现了一个js版本的A*算法,与之前不同的是,该A*算法是个双向A*. 双向A*有什么好处呢 ...
- 【腾讯bugly干货】QQ空间直播秒开优化实践
本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址为:http://bugly.qq.com/bbs/forum.php?mod=viewthread&tid=1204&am ...
- DBCP连接池使用问题
问题现象: 启动应用,访问无压力,一切正常,一段时间过后,应用访问异常. 问题分析: 1.web容器线程爆满,拒绝服务.由于应用并发量大,线程响应时间长增加,线程池连接数逐步递增直到爆满,导致应用拒绝 ...
- npm穿墙
GWF 很给力,很多东西都能墙掉,但是把 npm 也纳入黑名单,不知道 GWFer 是怎么想的.FQ翻了好多年了,原理其实也挺简单的,proxy 嘛! » 方法一 A) 国内源,http://cnpm ...
- jQuery.width()和jQuery.css('width')的区别
[TOC] 问题描述 使用jQuery修改一个div的宽度时,发现$($0).width('10rem')总是修改成不正确的值,然后使用$($0).css('width', '10rem')时却能正确 ...
- 泛型实现中没有正确lock引用类型的一个隐藏bug分析
最近看到这篇文章dotNetDR_的回复,让我想起一个真实发生的案例,下面就简单说说这个关于lock引用类型的一个不容易发现的隐藏缺陷. 某类库中的代码,封装了很简单的一个通用类,用于线程安全地执行某 ...