Cod sursa(job #3217812)
Utilizator | Ariana Bercea ariana6730hh | Data | 24 martie 2024 19:36:30 |
---|---|---|---|
Problema | Subsecventa de suma maxima | Scor | 100 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva educationala | Marime | 0.59 kb |
#include <iostream>
#include <fstream>
using namespace std;
ifstream in("ssm.in");
ofstream out("ssm.out");
int v[6000001],n,nr,imax,jmax,st;
int main()
{
in>>n;
for(int i=1; i<=n; i++)
in>>v[i];
long long s=0,Max=-100000;
for(int i=1; i<=n; i++)
{
if(v[i]+s<v[i])
{
st=i;
s=v[i];
}
else s+=v[i];
if(s>Max)
{imax=st;
jmax=i;
Max=s;
}
else if(s==Max)
if(i-st<jmax-imax)
imax=st, jmax=i;
}
out<<Max<<" "<<imax<<" "<<jmax;
}