最大连续子序列

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 31687    Accepted Submission(s): 14214

Problem Description
给定K个整数的序列{ N1, N2, ..., NK },其任意连续子序列可表示为{ Ni, Ni+1, ..., 
Nj },其中 1 <= i <= j <= K。最大连续子序列是所有连续子序列中元素和最大的一个, 
例如给定序列{ -2, 11, -4, 13, -5, -2 },其最大连续子序列为{ 11, -4, 13 },最大和 
为20。 
在今年的数据结构考卷中,要求编写程序得到最大和,现在增加一个要求,即还需要输出该 
子序列的第一个和最后一个元素。
 
Input
测试输入包含若干测试用例,每个测试用例占2行,第1行给出正整数K( < 10000 ),第2行给出K个整数,中间用空格分隔。当K为0时,输入结束,该用例不被处理。
 
Output
对每个测试用例,在1行里输出最大和、最大连续子序列的第一个和最后一个元 
素,中间用空格分隔。如果最大连续子序列不唯一,则输出序号i和j最小的那个(如输入样例的第2、3组)。若所有K个元素都是负数,则定义其最大和为0,输出整个序列的首尾元素。 
 
Sample Input
6
-2 11 -4 13 -5 -2
10
-10 1 2 3 4 -5 -23 3 7 -21
6
5 -8 3 2 5 0
1
10
3
-1 -5 -2
3
-1 0 -2
0
 
Sample Output
20 11 13
10 1 4
10 3 5
10 10 10
0 -1 -2
0 0 0
 
题解:
  int a[]; 保存输入的值。
  int s;   表示所求序列起点,
  int e;   表示所求序列终点,开始让s=e=a[0],然后逐步更新s,e。
  int flag;  表示以当前元素为结尾的 和最大 的子序列起点。
 
  定义一个变量mmax,用来更新 包括当前元素在内的 以及之前的 所有子序列的最大和。一个cnt统计 以当前元素为结尾的 子序列的最大和,
  每次循环,对于a[i],要计算以a[i]为结尾的子序列的最大和,怎么计算呢?
  先初始化cnt=0。从a[0]开始,
    如果原来的cnt<0,那么cnt+a[i]肯定比a[i]小,所以让cnt=a[i],把当前元素设为起点(flag=a[i]),再往后更新cnt。
    否则cnt+=a[i]。
   接着更新mmax,if(mmax<cnt) {mmax=cnt;s=flag;e=a[i];}
   遍历一遍之后mmax就是最大值
 
代码:
#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std; const int MAX=10001; int main()
{
int a[MAX];
int n;
while(scanf("%d",&n)!=EOF&&n)
{
int flag; //表示以当前元素为结尾的 "和(cnt)最大" 的子序列起点。
int cnt; //表示以当前元素为结尾的 "和(cnt)最大" 的子序列 的 "和"。
int mmax; //用来更新 包括当前元素在内的 以及之前的 所有子序列的最大和。
int s,e; //s表示所求序列起点,e表示所求序列终点,下面初始化的时候让s=e=a[0],然后逐步更新s,e。
for(int i=0;i<n;i++)
{
cin>>a[i];
}
cnt=0;
mmax=a[0];
s=e=a[0];
flag=a[0];
for(int i=0;i<n;i++)
{
if(cnt<0) //如果cnt<0,以当前元素为起点构成新的序列
{
cnt=a[i]; //
flag=a[i]; //设置起点
}
else
{
cnt+=a[i];
} if(mmax<cnt) //更新所求最大值
{
mmax=cnt;
s=flag; //设置所求序列起点
e=a[i]; //设置所求序列终点
}
}
if(mmax<0)
{
cout<<0<<" "<<a[0]<<" "<<a[n-1]<<endl;
continue;
}
else
{
cout<<mmax<<" "<<s<<" "<<e<<endl;
} }
return 0;
}

  

HDU1231 最长连续子序列的更多相关文章

  1. hdu1231 最长连续子序列和

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1231 给定K个整数的序列{ N1, N2, ..., NK },其任意连续子序列可表示为{ Ni, N ...

  2. TOJ 5065: 最长连续子序列

    5065: 最长连续子序列   Time Limit(Common/Java):1000MS/3000MS     Memory Limit:65536KByteTotal Submit: 140   ...

  3. 【TOJ 5065】最长连续子序列(前缀和)

    Description 给定一系列非负整数,求最长的连续子序列,使其和是7的倍数. Input 第一行为正整数N(1<=N<=50000),接下来有N行,每行有一个非负整数,所有整数不大于 ...

  4. 最长连续子序列 Longest Consecutive Sequence

    2018-11-25 16:28:09 问题描述: 问题求解: 方法一.如果不要求是线性时间的话,其实可以很直观的先排序在遍历一遍就可以得到答案,但是这里明确要求是O(n)的时间复杂度,那么就给了一个 ...

  5. POJ2479(最长连续子序列和)

    Maximum sum Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 37035   Accepted: 11551 Des ...

  6. leetcode 128. 最长连续子序列

    题目描述: 给定一个未排序的整数数组,找出最长连续序列的长度. 要求算法的时间复杂度为 O(n). 示例: 输入:[100, 4, 200, 1, 3, 2] 输出:4 即最长的连续序列为 [1,2, ...

  7. 最长连续子序列(dp,分而治之递归)

    5227: 最大子列和问题 时间限制(普通/Java):1000MS/3000MS     内存限制:65536KByte 总提交: 76            测试通过:46 描述 给定KK个整数组 ...

  8. HDU 3308 线段树单点更新+区间查找最长连续子序列

    LCIS                                                              Time Limit: 6000/2000 MS (Java/Oth ...

  9. BNUOJ 4215 最长公共连续子序列

    最长公共连续子序列 Time Limit: 1000ms Memory Limit: 65536KB   64-bit integer IO format: %lld      Java class ...

随机推荐

  1. java 常用API 时间 练习

    package com.orcal.demc01; import java.util.Date; public class Xuexi { public static void main(String ...

  2. nginx强制使用https访问(多站点多域名配置)

    很多配置过https模板的人都知道,配置https 时 ,站在用户的角度http 和https 的区别根本不清楚.有时候敲 http 时会出现 404 错误,而实际上我们是https. 有朋友找我配置 ...

  3. Nginx Location指令配置及常用全局变量

    ./configure的含义 在实践安装nginx的时候,不知道./configure是什么意思,这里特地记录一下. 在linux中./代表当前目录,属于相对路径../代表上一级目录,属于相对路径/代 ...

  4. python笔记4----字典

    1.哈希: 输入任意长度,输出固定长度. 即判断是否哈希,即判断可不可变. 2.创建字典 (1)直接创建:dic={1:'a',2:'b',3:'c'} (2)dict函数创建: list=[(1,' ...

  5. jquery.lazyload滚动不起作用

    昨天同事在开发图片懒加载功能时用到了lazyload,使用相当标准,然而结果却不如人意,在滚动时未能起作用.引用https://cdn.bootcss.com/jquery_lazyload/1.9. ...

  6. js操作table中tr的顺序,实现上移下移一行的效果

    总体思路是在table外部加个div,修改div的innerHtml实现改变tr顺序的效果 具体思路是 获取当前要移动tr行的rowIndex,在table中删除掉,然后循环table的rows,到了 ...

  7. N3-1 - 数组 - convert-sorted-array-to-binary-search-tree

    题目描述: Given an array where elements are sorted in ascending order, convert it to a height balanced B ...

  8. selenium+java处理鼠标悬停

    1.元素比较明确(可视) 2.元素隐藏,需要鼠标移动到一定地方才显现(下图为某论坛列表,需要将鼠标移动到列表才显示操作按钮)

  9. BA-Honeywell R300系统

  10. Eclipse设置jdk相关

    2.window->preferences->java->Compiler->设置右侧的Compiler compliance level 3.window->prefe ...