Cod sursa(job #1528994)
Utilizator | Data | 20 noiembrie 2015 13:36:19 | |
---|---|---|---|
Problema | Subsecventa de suma maxima | Scor | 70 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.63 kb |
#include <iostream>
#include <fstream>
using namespace std;
ifstream f("ssm.in");
ofstream o("ssm.out");
int main()
{
double suma,sumaMin,pozMin,pozStart,pozFin,maxim,i,n,x;
f>>n;
f>>x;
suma=x;
sumaMin=x;
pozMin=1;
pozStart=0;
pozFin=1;
maxim=x;
for(i=2;i<=n;i++){
f>>x;
suma+=x;
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;
}