码迷,mamicode.com
首页 > 其他好文 > 详细

careercup-中等难度 17.8

时间:2014-12-13 10:46:11      阅读:153      评论:0      收藏:0      [点我收藏+]

标签:style   blog   io   ar   color   os   sp   for   div   

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

标签:style   blog   io   ar   color   os   sp   for   div   

原文地址:http://www.cnblogs.com/wuchanming/p/4160973.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!