Cod sursa(job #1461051)
| Utilizator | Data | 14 iulie 2015 16:27:30 | |
|---|---|---|---|
| Problema | Subsecventa de suma maxima | Scor | 95 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.64 kb |
#include <fstream>
using namespace std;
int x[6000001];
int main()
{
ifstream fin("ssm.in");
ofstream fout("ssm.out");
int n,i,ic,smax,im,sf,sc;
fin>>n;
for(i=1;i<=n;i++)
{
fin>>x[i];
}
sc=smax=x[1];
ic=im=sf=1;
for(i=2;i<=n;i++)
{
if(sc+x[i]<x[i])
{
sc = x[i];
ic=i;
}
else
{
sc=sc + x[i];
if(sc>smax)
{
smax=sc;
im=ic;
sf=i;
}
}
}
fout<<smax<<" "<<im<<" "<<sf<<"\n";
return 0;
}
