最大连续子序列和问题(Maximum Consecutive Subsequence Sum)

  该算法的定义是:给出一个int序列,元素有正有负,找出其中的最大连续子序列的和。

  例如:-2,11,-4,13,-5-2,;最大和为20(11,-4, 13)。

  怎么考虑这个问题呢?

  要充分利用,连续,这个条件。

  连续子序列的和可能为正,也可能为负。如果为正,那么我们要继续加下去,因为如果后面一个数是正数,

最大子序列和必定包括前序列的和(毕竟前者和为正),如果后面一个是负数,我们也加,直到子序列的和不为正为止。

因为它不为正,所以如果后面有更大的连续子序列,那么也不会包括它,因为加上一个非正数不会更大。所以要重新开始计数。

  此时还有一个问题。如果全是正数,那么越加越大,没问题。但如果突然加上一个负数,后面又没有更大的连续子序列,即使加后的

和为正,我们也找不到比未加前更大的连续子序列了。所以我们还需要另外一个变量来保存最大连续子序列的和。

  考虑了这两点,那么算法也就很简单了,下面给出java写的程序示例。

	public static int maxSubSum(int[] array)
	{
		int max = 0, tmp = 0;
		for (int i = 0; i < array.length; i++) {
			tmp += array[i];
			if (tmp > max) {
				max = tmp;
			}
			else if(tmp <= 0){
				tmp = 0;
			}
		}
		return max;
	}

  

时间: 2024-08-05 00:28:35

最大连续子序列和问题(Maximum Consecutive Subsequence Sum)的相关文章

hdu 1231 最大连续子序列(DP)

最大连续子序列 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 21166    Accepted Submission(s): 9387 Problem Description 给定K个整数的序列{ N1, N2, ..., NK },其任意连续子序列可表示为{ Ni, Ni+1, ..., Nj },其中 1 <= i <= j

Maximum Subsequence Sum 最大子序列和的进击之路

本文解决最大子序列和问题,有两个题目组成,第二个题目比第一个要求多一些(其实就是要求输出子序列首尾元素). 01-复杂度1 最大子列和问题   (20分) 给定KK个整数组成的序列{ N1??, N2??, ..., NK?? },"连续子列"被定义为{ N?i??, Ni+1 ..., Nj },其中 1≤i≤j≤K."最大子列和"则被定义为所有连续子列元素的和中最大者.例如给定序列{ -2, 11, -4, 13, -5, -2 },其连续子列{ 11, -4,

dynamic programming 之Maximum Sub-Sequence Sum(最大子序列和问题)

问题描述: 给定一个整数序列, 序列中可能有负数. 目的是找出这个序列的连续子序列(即子序列的元素的选取是连续的从序列中选取的).即通过确定i, j 的值,  使得的值达到最大. 我们定义, 当所有的元素为负数值的时候, 那么maximum subsequence sum 为0. 下面我们用动态规划的技术去求解. 为了找到最大连续子序列和,  不难看出, 在扩展我们的求和窗口的时候, 当新加进窗口的元素市负数的时候, 只要我们得到的新的求和窗口的值求和不是负数, 那么我们就不能丢掉这个新的负数.

UVa 108 - Maximum Sum(最大连续子序列)

题目来源:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=3&page=show_problem&problem=44  Maximum Sum  Background A problem that is simple to solve in one dimension is often much more difficult to solve in more th

leetcode | Maximum Subarray 最大连续子序列的和

Maximum Subarray: https://leetcode.com/problems/maximum-subarray/ Find the contiguous subarray within an array (containing at least one number) which has the largest sum. For example, given the array [?2,1,?3,4,?1,2,1,?5,4], the contiguous subarray [

lintcode 容易题:Longest Increasing Continuous subsequence 最长上升连续子序列

题目: 最长上升连续子序列 给定一个整数数组(下标从 0 到 n-1, n 表示整个数组的规模),请找出该数组中的最长上升连续子序列.(最长上升连续子序列可以定义为从右到左或从左到右的序列.) 样例 给定 [5, 4, 2, 1, 3], 其最长上升连续子序列(LICS)为 [5, 4, 2, 1], 返回 4. 给定 [5, 1, 2, 3, 4], 其最长上升连续子序列(LICS)为 [1, 2, 3, 4], 返回 4. 解题: 这个直接找就可以了,最长的升序,和最长的降序,再求最大值,时

codeforce 977 F. Consecutive Subsequence

F. Consecutive Subsequence time limit per test 2 seconds memory limit per test 256 megabytes input standard input output standard output You are given an integer array of length nn. You have to choose some subsequence of this array of maximum length

[PTA] PAT(A) 1007 Maximum Subsequence Sum (25 分)

目录 Problem Description Input Output Sample Sample Input Sample Output Solution Analysis Code Problem portal: 1007 Maximum Subsequence Sum (25 分) Description Given a sequence of $K$ integers { $N_{1}?$, $N_{2}?$, $...$, $N_{K}$ }. A continuous subsequ

Maximum Subsequence Sum - 最大子列和问题_C语言实现

第一次写这方面的blog.自己也是初次接触相关知识,写的有不妥的地方十分欢迎大家指正~ 这是浙大PAT上的一道算法题(据说是浙大04年研究生复试题),题目是这样的: Maximum Subsequence Sum Given a sequence of KK integers { N_1N?1??, N_2N?2??, ..., N_KN?K?? }. A continuous subsequence is defined to be { N_iN?i??, N_{i+1}N?i+1??, ..