首页 > 其他 > 详细

最大字段和

时间:2019-03-09 18:39:00      阅读:189      评论:0      收藏:0      [点我收藏+]

算法步骤

1、用 cur 维护当前和 (初始化为0),用 res 保存最终结果 (初始化为 -inf),用 temp 维护开始的位置

2、遍历 a 数组,cur+=a[i] ,如果 cur < 0,则 cur=0 ,temp=i+1从新开始

3、如果 cur>res,更新res=cur,l=temp,r=i

 

技术分享图片
#include<iostream>
#include<algorithm>
using namespace std;
const int maxn = 100010;
const int inf = 0x7fffffff;

int n,l,r;
int a[maxn];
long long maxSum(){
    long long cur = 0,res=-inf;
    int temp = 1;
    for (int i = 1; i <= n; i++){
        cur += 1ll*a[i];
        if (cur > res){
            res = cur;
            l = temp;
            r = i;
        }
        if (cur < 0){
            cur = 0;
            temp = i + 1;
        }
    }
    return res;
}
int main()
{
    cin >> n;
    for (int i = 1; i <= n; i++)
        cin >> a[i];

    cout << maxSum()<<" ";
    cout<< l <<" "<< r << endl;

    return 0;
}
View Code

 

最大字段和

原文:https://www.cnblogs.com/looeyWei/p/10502386.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!