Cod sursa(job #1528996)
| Utilizator | Data | 20 noiembrie 2015 13:39:03 | |
|---|---|---|---|
| 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>maxim+sumaMin){
maxim=suma-sumaMin;
pozStart=pozMin;
pozFin=i;
}
if(sumaMin>suma){
sumaMin=suma;
pozMin=i;
}
}
o<<maxim<<" "<<pozStart+1<<" "<<pozFin;
return 0;
}
