动态规划 HDU1231-------最大连续子序列
这道题貌似有很多前辈总结过,写写自己是怎样理解的吧。
1 #include <iostream> 2 #include <cstdio> 3 4 using namespace std; 5 int num[10008]; 6 7 int main() 8 { 9 int K,start,end,thisMax,MAX; 10 while(scanf("%d",&K)&&K) 11 { 12 int count=0,temp; 13 for(int i=0;i<K;i++) {scanf("%d",&num[i]);if(num[i]<0) count++;} 14 15 if(count==K) {printf("0 %d %d\n",num[0],num[K-1]);continue;} 16 start=end=0; 17 thisMax=MAX=num[0]; 18 19 for(int i=1;i<K;i++) 20 { 21 if(thisMax<0) 22 { 23 temp=i; 24 thisMax=0; 25 } 26 thisMax+=num[i]; 27 28 if(thisMax>MAX) 29 { 30 start=temp; 31 end=i; 32 MAX=thisMax; 33 } 34 } 35 printf("%d %d %d\n",MAX,num[start],num[end]); 36 } 37 return 0; 38 }
View Code
设这一数组是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;
这就是我的理解。
转载于:https://www.cnblogs.com/Chinahenu/p/3914203.html
动态规划 HDU1231-------最大连续子序列相关推荐
- HDU1231 最大连续子序列【最大子段和】
最大连续子序列 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...
- HDU1231(最大连续子序列)
给定K个整数的序列{ N1, N2, ..., NK },其任意连续子序列可表示为{ Ni, Ni+1, ..., Nj },其中 1 <= i <= j <= K.最大连续子序列是 ...
- 最大连续子序列和-动态规划
题目描述: 给定K个整数的序列{ N1, N2, -, NK },其任意连续子序列可表示为{ Ni, Ni+1, -, Nj },其中 1 <= i <= j <= K.最大连续子序 ...
- 动态规划--连续子序列的最大和
给定k个整数的序列{N1,N2,...,Nk },其任意连续子序列可表示为{ Ni, Ni+1, ..., Nj },其中 1 <= i <= j <= k.最大连续子序列是所有连续 ...
- 54 - 算法 - 动态规划问题 连续子序列和最大
#define _CRT_SECURE_NO_WARNINGS #include <iostream> #include <cstdio> #include <cmath ...
- 算法--最大连续子序列和(动态规划,分而治之)
今天在LeetCode上遇到一个求最大连续子序列和的问题,如下: Given an integer array nums, find the contiguous subarray (containi ...
- 【恋上数据结构】动态规划(找零钱、最大连续子序列和、最长上升子序列、最长公共子序列、最长公共子串、0-1背包)
动态规划(Dynamic Programming) 练习1:找零钱 找零钱 - 暴力递归 找零钱 - 记忆化搜索 找零钱 - 递推 思考题:输出找零钱的具体方案(具体是用了哪些面值的硬币) 找零钱 - ...
- 动态规划经典题目——最大连续子序列之和
一.题目 给定K个整数的序列{ N1, N2, -, NK },其任意连续子序列可表示为{ Ni, Ni+1, -, Nj },其中 1 <= i <= j <= K.最大连续子序列 ...
- 最大连续子序列和:动态规划经典题目
[题目] 给定k个整数的序列{N1,N2,...,Nk },其任意连续子序列可表示为{ Ni, Ni+1, ..., Nj },其中 1 <= i <= j <= k.最大连续子序列 ...
最新文章
- linux服务器安全
- PHP的$_FILES
- vue 固定div 滚动_vue移动端 导航吸顶(固定定位)页面滚动出现抖动
- Mysql Too many connections解决方法
- java葵花宝典_JAVA程序员想入职跳槽,这些基本功一定要做好,你给自己打几分?...
- 检测到在集成的托管管道模式下不适用的 ASP.NET 设置, HTTP 错误 500.23 解决方案...
- 在vue中实现picker样式_基于Vue实现timepicker
- CentOS 7 防火墙命令
- C++ 整型所能表示的数据范围
- ELK --- Grok正则过滤Linux系统登录日志
- ashx 使用Session
- 综合项目之闪讯破解(五)之 如何用C#调用C++编写的Dll
- Vue2.0+组件库总结
- 用户名片 3:页面实现
- Ceph Peering以及数据均衡的改进思路
- 全国大学计算机专业排名2021,2021全国计算机专业大学排名一览表
- 3个老鼠确定8个瓶子哪瓶有毒
- 时间序列压缩算法及其应用
- 【51单片机】矩阵按键实现数码管显示
- 蒋松廷 荣获第六季完美童模全球总决赛 全球总冠军
热门文章
- javascript-按圆形排列DIV元素(三)实例---- 图片按椭圆形转动
- petshop 4.0的数据持久层
- java.lang.OutOfMemoryError 解决方式
- 初学 C 语言没有项目练手?这 20 个小项目拿走不谢~
- pydev集成mysql_【Python】Windows平台下Python、Pydev连接Mysql数据库
- 企业防火墙代替路由器_「防火墙技术连载」基础知识篇 1、什么是防火墙
- Nacos支持配置的动态更新
- Nginx安装方式介绍
- Protobuf序列化的原理-protobuf的基本应用
- 商品评价 - 实现分页