Cod sursa(job #2104534)
Utilizator | Data | 11 ianuarie 2018 19:54:46 | |
---|---|---|---|
Problema | Subsecventa de suma maxima | Scor | 85 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.41 kb |
#include <bits/stdc++.h>
using namespace std;
ifstream fin ("ssm.in");
ofstream fout ("ssm.out");
int main()
{
long long s,smax,x,n,st=1,dr=1,m;
fin>>n;
fin>>x;
s=smax=x;
if (s<0) s=0;
for (int i=2;i<=n;i++)
{
fin>>x;
s+=x;
if (s>smax) smax=s,dr=i,st=m;
if (s<0) s=0,m=i+1;
}
fout<<smax<<" "<<st<<" "<<dr;
return 0;
}