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 ...
随机推荐
- Xml生成节点声明
XmlDocument xmlDoc = new XmlDocument(); XmlDeclaration declaration = xmlDoc.CreateXmlDeclaration(&qu ...
- 使用CSS中的meta实现web定时刷新或跳转的方法
这篇文章主要介绍了使用CSS中的meta实现web定时刷新或跳转的方法,比使用JavaScript脚本实现起来更加简单一些,需要的朋友可以参考下 meta源信息功能之页面定时跳转与刷新 几乎所有的网页 ...
- 经典排序算法(PHP)
1.冒泡算法,排序算法,由于在排序过程中总是小数往前放,大数往后放,相当于气泡往上升,所以称作冒泡排序 function maopao_fun($array){ $count = count($arr ...
- JAVA 求和程序
- EI Index
Journal of Software (JoS). China. [link]
- Win10 无法完全关机问题
Win10是重新安装的.开机运行时间长了或者跑的东西多了.关机,键盘灯还是亮的,要强制按电源键关机才行. 问题解决:从网上搜以为是显卡驱动问题,上官网更新最新驱动,结果还是关不了机.偶然间搜到是Int ...
- [ASE]sprint2 总结 & sprint3计划
第二个sprint半圆满的结束了, 经历了四周之后我们将整个的框架搭建好,并且能够正常的游戏对战,破坏场景,聊天…… 但是正如老师所述,缺乏亮点. 不过大家都是第一次做,完全把他当成一个工程来一点一点 ...
- Android 自定义View 三板斧之三——重写View来实现全新控件
通常情况下,Android实现自定义控件无非三种方式. Ⅰ.继承现有控件,对其控件的功能进行拓展. Ⅱ.将现有控件进行组合,实现功能更加强大控件. Ⅲ.重写View实现全新的控件 本文来讨论最难的一种 ...
- 一种基于Orleans的分布式Id生成方案
基于Orleans的分布式Id生成方案,因Orleans的单实例.单线程模型,让这种实现变的简单,贴出一种实现,欢迎大家提出意见 public interface ISequenceNoGenerat ...
- 《JAVA与模式》之抽象工厂模式
场景问题 举个生活中常见的例子——组装电脑,我们在组装电脑的时候,通常需要选择一系列的配件,比如CPU.硬盘.内存.主板.电源.机箱等.为讨论使用简单点,只考虑选择CPU和主板的问题. 事实上,在选择 ...