首页 > 代码库 > careercup-中等难度 17.8

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;}

 

careercup-中等难度 17.8