给出一个由[-100,100]之间整数组成的数组,求其相加和最大的连续子数组 输入 一个连续整数组成的数组 输出 子数组相加的最大值 样例输入 -...

给出一个由[-100,100]之间整数组成的数组,求其相加和最大的连续子数组
解题:时间复杂度为O(N),也能解决最大子序列和为负数的情况
输入

  一个连续整数组成的数组

输出

  子数组相加的最大值

样例输入

  -1 2 3 -2 4 -6

样例输出

7

python版本:

import math
print("数组")
x=input()
x=[-1,-2,-3,-2,-4,-6]
x=x.split(" ")
x = [int(x[i]) for i in range(len(x))]
sum=0
max_x=x[0]
for i in range(len(x)):
    sum += x[i]
    if (sum > max_x):
        max_x = sum
    if (sum < 0):
        sum = 0
//如果最大子序列是负数,则取序列里面最大的数即可
if(sum==0):
    max_x=max(x)
print(max_x)

c++版本:
由于输入原因,所以时间有点长

#include 
#include 
#include
#include 
#include 
using namespace std;

int main()
{
    vector arr;
    int i = 0;
    int n=0;
    do{
        cin >> i;
        n++;
        arr.push_back(i);
    }while(getchar() !='\n');
//    int arr[6]= {-1,2,3,-2,4,-6};
    int max = arr[0];
    for(int i = 0, sum = 0; i < n; ++i)
    {
        sum += arr[i];
        if (sum > max)
            max = sum;
        if (sum < 0)
            sum = 0;
    }
    printf("%d",max);
    system("pause");
    return 0;
}

你可能感兴趣的:(给出一个由[-100,100]之间整数组成的数组,求其相加和最大的连续子数组 输入 一个连续整数组成的数组 输出 子数组相加的最大值 样例输入 -...)