Pagini recente » Cod sursa (job #2907580) | Cod sursa (job #2283649) | Cod sursa (job #2841635) | Cod sursa (job #1612977) | Cod sursa (job #679050)
Cod sursa(job #679050)
//O (N)
#include <cstdio>
#include <iostream>
using namespace std;
#define maxN 6000005
#define INF 0x3f3f3f3f
int N , x[maxN] , s[maxN] , best;
int main ()
{
freopen ("ssm.in" , "r" , stdin);
freopen ("ssm.out" , "w" , stdout);
scanf ("%d" , &N);
for (int i = 1 ; i <= N ; ++i)
{
scanf ("%d" , &x[i]);
s[i] = s[i - 1] + x[i];
}
int min = 0 , sol = -INF , start , stop , aux_start;
for (int i = 1 ; i <= N ; ++i)
{
best = s[i] - min;
if (best > sol)
{
sol = best;
start = aux_start;
stop = i;
}
if (s[i] < min)
{
min = s[i];
aux_start = i + 1;
}
}
printf ("%d %d %d" , sol , start , stop);
return 0;
}