Cod sursa(job #1528989)
| Utilizator | Data | 20 noiembrie 2015 13:28:04 | |
|---|---|---|---|
| Problema | Subsecventa de suma maxima | Scor | 20 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.65 kb |
#include <iostream>
#include <fstream>
using namespace std;
ifstream f("ssm.in");
ofstream o("ssm.out");
int main()
{
int suma,sumaMin,pozMin,pozStart,pozFin,maxim,v[1002],i,n;
f>>n;
f>>v[1];
suma=v[1];
sumaMin=v[1];
pozMin=1;
pozStart=0;
pozFin=1;
maxim=v[1];
for(i=2;i<=n;i++){
f>>v[i];
suma+=v[i];
if(suma-sumaMin>maxim){
maxim=suma-sumaMin;
pozStart=pozMin;
pozFin=i;
}
if(sumaMin>suma){
sumaMin=suma;
pozMin=i;
}
}
o<<maxim<<" "<<pozStart+1<<" "<<pozFin;
return 0;
}
