Pagini recente » Monitorul de evaluare | Diferente pentru problema/sokoban intre reviziile 2 si 3 | Cod sursa (job #1588363) | Diferente pentru problema/expand intre reviziile 16 si 15 | Cod sursa (job #1991107)
#include <fstream>
using namespace std;
ifstream fi("ssm.in");
ofstream fo("ssm.out");
//FILE * fi;
int n, i, smax, sum, st, poz, lg;
int X[6000001];
int main()
{
fi>>n;
for(i=1;i<=n;i++)
fi>>X[i];
for(smax=sum=X[1], st=poz=1, lg=i=2; i<=n; i++)
if(sum<0)
sum=X[i], st=i; ///incepe o subsecventa noua, deoarece daca sum<0, cu siguranta sum+X[i]<X[i]
else
{
sum += X[i];
if(smax<sum)
smax=sum, poz=st, lg=i-st+1;
}
fo<<smax<<' '<<poz<<' '<<poz+lg-1;
fi.close();
fo.close();
return 0;
}