3、求子数组的最大和

3.求子数组的最大和
题目:
输入一个整形数组,数组里有正数也有负数。
数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和。
求所有子数组的和的最大值。要求时间复杂度为O(n)。
例如输入的数组为1, -2, 3, 10, -4, 7, 2, -5,和最大的子数组为3, 10, -4, 7, 2,
因此输出为该子数组的和18。

 

思路:

方法1: 列举出所有的连续的子数组,然后求和比较求最大值,

方法2:

假设有下标a,b, 0<a<b<n, array[a...b]的和为最大和,则需要满足的条件是

对任意的x,0<= x <= a-1, 都有array[x ... a-1] 的和为负数, 若不为负数,那么 array[x...b] = array[x ... a-1] + array[a...b] > array[a...b],说明array[a...b]不是最大值,与假设矛盾。

所以当array[0...x]的值为负数时,我们将其抛弃掉,将array[x+1...n-1]看做一个新的数组,运用递归的思想继续求最大值。

最大值存在时他的后一个数据必定为负数,或者已经到了数组的末尾。

 

下面是代码:

#include <iostream>
#include <cassert>

using namespace std;

int maxSubArraySum(int *arr, int length)
{
	assert(length > 0);
	int maxSum = arr[0];
	int sum = arr[0];

	for (int index = 1; index < length; index++)
	{
		if (sum < 0)
		{
			if (maxSum < sum)
			{
				maxSum = sum;
			}
			sum = arr[index];
		}
		else 
		{
			if (arr[index] < 0)
			{
				if (maxSum < sum)
				{
					maxSum = sum;
				}
			}
			sum += arr[index];
		}
	}

	if (maxSum < sum)
	{
		maxSum = sum;
	}

	return maxSum;
}

int main(void)
{
	//int arr[] = {1, -2, 3, 10, -4, 7, 2, -5};
	int arr[] = {-11, -2, -3, -10, -14, -7, -12, -5};
	int length = 8;

	cout << maxSubArraySum(arr, length) << endl;

	system("Pause");

	return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值