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 ...
随机推荐
- Java学习笔记五——流程控制
分支结构 Java提供了两种常见的分支控制结构:if语句和switch语句. if语句 if语句使用布尔值或布尔表达式(表达式结果为布尔值),if语句有3中形式: 第一种形式: if (5 > ...
- “设计之变”--从iPhone应用到iPad应用
在做APP的iPad版本设计时,我们常常需要考虑:如何在延续iPhone版本设计特色和优点同时,充分利用iPad的特性更好地进行设计.本文从iPad和iPhone的差异性入手,试图总结这一设计过程中需 ...
- unity发布安卓 截图保存到本地
using System.IO; //获取系统时间并命名相片名 System.DateTime now = System.DateTime.Now; string times = now.ToStri ...
- Linux环境下解压超过4GB的zip文件
今天在Linux服务器中解压一个zip的压缩包,提示如下错误信息: [root@appsrv01 ZIP_BCSA_COURSES]# unzip BCSA_MEDIAS_BAK_20161118.z ...
- java 并发性和多线程 -- 读感 (二 线程间通讯,共享内存的机制)
参考文章:http://ifeve.com/java-concurrency-thread-directory/ 其中的竞态,线程安全,内存模型,线程间的通信,java ThreadLocal类小节部 ...
- rlwrap-0.37.tar.gz实现sqlplus上下翻页
1.上传rlwrap-0.37.tar.gz到linux 2.解压rlwrap-0.37.tar.gz [root@node1 mnt]# tar zxvf rlwrap-0.37.tar.gz [r ...
- openwrt-智能路由器hack技术(2)---"网路信息监控和窃取"
openwrt-智能路由器hack技术(2)---"网路信息监控和窃取" 1 导读 PS:之前写的一个文章,现在发现结构内容排版不是太好,导致阅读体验太差,影响传播和SEO,所 ...
- python--批量下载豆瓣图片
溜达豆瓣的时候,发现一些图片,懒得一个一个扒,之前写过c#和python版本的图片下载,因此拿之前的Python代码来改了改,折腾出一个豆瓣版本,方便各位使用 # -*- coding:utf8 -* ...
- Java多线程系列--“JUC锁”05之 非公平锁
概要 前面两章分析了"公平锁的获取和释放机制",这一章开始对“非公平锁”的获取锁/释放锁的过程进行分析.内容包括:参考代码获取非公平锁(基于JDK1.7.0_40)释放非公平锁(基 ...
- java提高篇(十二)-----代码块
在编程过程中我们可能会遇到如下这种形式的程序: public class Test { { //// } } 这种形式的程序段我们将其称之为代码块,所谓代码块就是用大括号({})将多行代码封装在一起, ...