其他分享
首页 > 其他分享> > 1007 Maximum Subsequence Sum

1007 Maximum Subsequence Sum

作者:互联网

#include <iostream>
#include <vector>
#include <cstdio>
using namespace std;
int main()
{
    int n;
    cin >> n;
    vector<int> arr(n);
    int sum=-1;//最大连续子序列和
    int tempsum=0;//临时的连续子序列和
    int left=0;//最大子序列左下标
    int right=0;//最大子序列右下标
    int index=0;//临时的序列左下标
    bool flag = true;//检验是否全是负数
    for(int i=0; i<n; i++){
        scanf("%d", &arr[i]);
        if(arr[i] >= 0)
            flag = false;
        tempsum += arr[i];
        if(tempsum > sum){
            sum = tempsum;
            left = index;
            right = i;
        }else if(tempsum < 0){//如果临时序列和已经小于sum的情况下还是负数,应该舍弃之前的序列
            index = i+1;
            tempsum = 0;
        }
    }
    if(flag){
        printf("0 %d %d", arr[0], arr[n-1]);
    }else{
        printf("%d %d %d", sum, arr[left], arr[right]);
    }
    return 0;
}

标签:arr,right,int,sum,Maximum,序列,Subsequence,tempsum,1007
来源: https://blog.csdn.net/yyd_s/article/details/122614458