Cod sursa(job #1995788)
Utilizator | Data | 29 iunie 2017 09:04:16 | |
---|---|---|---|
Problema | Subsecventa de suma maxima | Scor | 95 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 1.68 kb |
#include <fstream>
using namespace std;
ifstream in("ssm.in");
ofstream out("ssm.out");
int main()
{
int n,i,j,sc=0,nr,k,mx=-(1<<31-1),a,b,ct=0;
in>>n;
for(i=1; i<=n; i++)
{
in>>nr;
sc+=nr;
ct++;
if(sc<0)
{
sc=0;
ct=0;
}
else
{
if(sc>mx)
{
mx=sc;
a=i-ct+1;
b=i;
}
else if(sc==mx)
{
if(i-ct+1<a)
{
mx=sc;
a=i-ct+1;
b=i;
}
else if(i-ct+1==a)
{
if(i<b-a)
{
mx=sc;
a=i-ct+1;
b=i;
}
}
}
}
}
/*
for(i=0; i<=n; i++)
for(j=1; j<=n; j++)
{
for(k=j; k<=j+i; k++)
s+=v[k];
if(s>mx)
{
mx=s;
a=j;
b=j+i;
}
else if(s==mx)
{
mx=s;
if(j<a)
{
a=j;
b=j+i;
}
else if(j==a)
{
if(i<b-a)
{
a=j;
b=j+i;
}
}
}
s=0;
}*/
out<<mx<<" "<<a<<" "<<b;
return 0;
}