Cod sursa(job #3197792)
Utilizator | Data | 27 ianuarie 2024 14:39:33 | |
---|---|---|---|
Problema | Subsecventa de suma maxima | Scor | 90 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva educationala | Marime | 0.63 kb |
#include <fstream>
#include <vector>
#include <limits.h>
#define ll long long
using namespace std;
ifstream cin("ssm.in");
ofstream cout("ssm.out");
long long n,smax=LLONG_MIN,sc;
int inc,sf,iaux;
int main()
{
cin>>n;
for(int i=1;i<=n;++i){
int a;
cin>>a;
if(sc+a >a)//continua secventa
{
sc+=a;
if(sc>smax) smax=sc,inc=iaux,sf=i;
}else{//secventa noua
sc=a;
iaux=i;
if(sc>smax){
smax=sc;
inc=iaux;
}
}
}
cout<<smax<<" "<<inc<<" "<<sf;
return 0;
}