动态规划 HDU1231-------最大连续子序列
这道题貌似有很多前辈总结过,写写自己是怎样理解的吧。
#include <iostream>
#include <cstdio> using namespace std;
int num[]; int main()
{
int K,start,end,thisMax,MAX;
while(scanf("%d",&K)&&K)
{
int count=,temp;
for(int i=;i<K;i++) {scanf("%d",&num[i]);if(num[i]<) count++;} if(count==K) {printf("0 %d %d\n",num[],num[K-]);continue;}
start=end=;
thisMax=MAX=num[]; for(int i=;i<K;i++)
{
if(thisMax<)
{
temp=i;
thisMax=;
}
thisMax+=num[i]; if(thisMax>MAX)
{
start=temp;
end=i;
MAX=thisMax;
}
}
printf("%d %d %d\n",MAX,num[start],num[end]);
}
return ;
}
设这一数组是a1,a2,.....,ai,ai+1,....an,首先初始化MAX=thisMAX=a1,start=end=1;然后对ai进行分析有MAX=(a[start],...,a[end]),thismax=(a[start],...,a[i-1]),其中i-1>=end;若thisMAX<0,则说明start......i-1中可以去掉end+1,...,i-1这一部分。对此我们可以用一个临时标界符temp来分开指示从i开始的连续和,这时thisMAX=0;开始新的求和,到此我们有两组“开始”,“结束”,”最大值“。第一组start,end,MAX;第二组:临时标界符temp,i-1,thismMAX;然后对i进行分析:
1.若ai<0,有假如thisMAX<0,则由于MAX至少大于等于0,所以不会更新;thisMAX>0(此时thisMAX一定是<=MAX的,不然在前面MAX的值一定会同步thisMAX的),又有thisMAX+ai<thisMAX<MAX,故仍旧不用更新
2.若ai>0,实际上就是上述的两组进行比较,若thisMAX>MAX,则进行更新start=temp,end=i;MAX=thisMAX;
这就是我的理解。
动态规划 HDU1231-------最大连续子序列的更多相关文章
- hdu1231最大连续子序列(动态规划)
最大连续子序列 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Sub ...
- 【动态规划】最大连续子序列和,最大子矩阵和,最大m子段和
1.最大字段和问题 求一个序列最大连续子序列之和. 例如序列[-1,-2,-3,4,5,-6]的最大子段和为4 + 5 = 9. ①枚举法 int MaxSum(int n,int *a){ int ...
- 动态规划:最大连续子序列乘积 分类: c/c++ 算法 2014-09-30 17:03 656人阅读 评论(0) 收藏
题目描述: 给定一个浮点数序列(可能有正数.0和负数),求出一个最大的连续子序列乘积. 分析:若暴力求解,需要O(n^3)时间,太低效,故使用动态规划. 设data[i]:第i个数据,dp[i]:以第 ...
- HDU 1081 To the Max 最大子矩阵(动态规划求最大连续子序列和)
Description Given a two-dimensional array of positive and negative integers, a sub-rectangle is any ...
- 题解报告:hdu1231最大连续子序列
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1231 Problem Description 给定K个整数的序列{ N1, N2, ..., NK } ...
- hdu1231 最大连续子序列
#include<stdio.h> #include<string.h> #define maxn 10010 int a[maxn],dp[maxn]; int main() ...
- hdu1231最大连续子序列
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=1231 #include<iostream> #include<cstdio> ...
- HDU-1231 简单dp,连续子序列最大和,水
1.HDU-1231 2.链接:http://acm.hdu.edu.cn/showproblem.php?pid=1231 3.总结:水 题意:连续子序列最大和 #include<iostre ...
- 动态规划(Dynamic Programming, DP)---- 最大连续子序列和
动态规划(Dynamic Programming, DP)是一种用来解决一类最优化问题的算法思想,简单来使,动态规划是将一个复杂的问题分解成若干个子问题,或者说若干个阶段,下一个阶段通过上一个阶段的结 ...
随机推荐
- 【linux】centos6.5上bugzilla的搭建
1.安装依赖包 CentOS 6.5默认安装了apche,perl ,需要安装httpd mod_ssl mysql-server mysql php-mysql gcc perl* mod_perl ...
- .NET实现WebSocket服务端即时通信实例
即时通信常用手段 1.第三方平台 谷歌.腾讯 环信等多如牛毛,其中谷歌即时通信是免费的,但免费就是免费的并不好用.其他的一些第三方一般收费的,使用要则限流(1s/限制x条消息)要么则限制用户数. 但稳 ...
- python 面向对象 初始化
参考学习: http://www.runoob.com/python/python-object.html 其中 函数里面 self.name 就是用 初始化的 name Employe.empCou ...
- hadoop2.6.0的eclipse插件编译和设置
编译hadoop2.6.0的eclipse插件 下载源码: git clone https://github.com/winghc/hadoop2x-eclipse-plugin.git 编译源码: ...
- ExtJS组件扩展
1.extends 2.initComponent 3.constracot: 4.onRender:重新写这个方法 ========================================= ...
- cesium初始化参数
var viewer = new Cesium.Viewer('cesiumContainer',{ animation:false, //动画控制不显示 //baseLayerPicker:fals ...
- hadoop学习day3 mapreduce笔记
1.对于要处理的文件集合会根据设定大小将文件分块,每个文件分成多块,不是把所有文件合并再根据大小分块,每个文件的最后一块都可能比设定的大小要小 块大小128m a.txt 120m 1个块 b.txt ...
- PHP报错open_basedir restriction in effect
问题是出现在了PHP.INI上面了 原因是php.ini里设置了 open_basedir=/var/web/w0895/:/tmp:/usr/lib/php 这里加上相关的目录就可以了 解答:其实o ...
- 数据挖掘比赛----Kaggle实战
http://www.cnblogs.com/kobedeshow/p/4118361.html
- css常用属性初总结:font
平时在做项目时,UX常说的一句话就是“这里的字体不对吧,字体大小也不太对,你们前端有没有按规范来”,今天,我们就一起来看看这折磨人的font属性. 字体属性font-family 允许值 系列名 初始 ...