首页 > 其他 > 详细

hdu 1003 MaxSum 最大子段和

时间:2019-03-09 18:51:47      阅读:193      评论:0      收藏:0      [点我收藏+]

题目链接http://acm.hdu.edu.cn/showproblem.php?pid=1003

 

技术分享图片
#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()
{
    int t,k=1;
    cin >> t;
    while (t--){
        cin >> n;
        for (int i = 1; i <= n; i++)
            cin >> a[i];
        cout << "Case " << k++ << ":" << endl;
        cout << maxSum()<<" ";
        cout<< l <<" "<< r << endl;
        if (t != 0) cout << endl;
    }
    return 0;
}
View Code

 

hdu 1003 MaxSum 最大子段和

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

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