careercup-中等难度 17.8

17.8 给定一个整数数组(有正数和负数),找出总和最大的连续序列,并返回总和。

解法:

就是求连续子序列的和最大,不过存在一个问题:

假设整个数组都是负数,怎么样才是正确的行为呢?看看这个简单的数组{-3,-10,-5},一下答案每个都可以说的通:

-3(假设子序列不能为空)

0(子序列的长度为空)

INT_MIN(视为错误的情况)

我们会选择第二种(maxSum=0),但并没有所谓的“正确”答案。这一点可以跟面试官好好讨论一番。

C++实现代码:

#include<iostream>
using namespace std;

int getMaxSum(int a[],int n)
{
    int sum=0;
    int maxSum=0;
    int i;
    for(i=0;i<n;i++)
    {
        sum+=a[i];
        if(sum>maxSum)
            maxSum=sum;
        if(sum<0)
            sum=0;
    }
    return maxSum;
}

int main()
{
    int arr[10]={1,-4,-3,8,-4,9,3,-7,5,3};
    cout<<getMaxSum(arr,10)<<endl;
}
原文地址:https://www.cnblogs.com/wuchanming/p/4160973.html