Cod sursa(job #1042928)
Utilizator | Data | 27 noiembrie 2013 19:56:55 | |
---|---|---|---|
Problema | Subsecventa de suma maxima | Scor | 95 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.62 kb |
#include<iostream>
#include<fstream>
using namespace std;
ifstream f("ssm.in");
ofstream g("ssm.out");
int n;
int main()
{
int s=0, x, i, maxi=0, pozi=1, pozs=1, pozsmax, pozimax;
f>>n;
for(i=1;i<=n;i++)
{
if(s>maxi)
{
maxi=s;
pozs=i;
pozsmax=pozs;
pozimax=pozi;
}
f>>x;
s+=x;
if(s<0)
{
s=0;
pozi=i+1;
}
}
if(s>maxi)
{
maxi=s;
pozsmax=n+1;
}
g<<maxi<<" "<<pozimax<<" "<<pozsmax-1<<" ";
}