Pagini recente » Cod sursa (job #1637787) | Cod sursa (job #166167) | Cod sursa (job #767193) | Cod sursa (job #2788111) | Cod sursa (job #882725)
Cod sursa(job #882725)
/*#include <iostream>
#include <fstream>
#include <limits>
using namespace std;
ifstream f("ssm.in");
ofstream g("ssm.out");
int n,i,s,smax=numeric_limits<int>::min(),lg,ind=1,x,st;
int main()
{
f>>n;
for (i=1;i<=n;i++)
{
f>>x;
if (s<0)
{
ind=i;
s=x;
}
else s+=x;
if (s>smax)
{
st=ind;
lg=i;
smax=s;
}
}
g<<smax<<" "<<st<<" "<<lg;
return 0;
}*/
#include <iostream>
#include <fstream>
#include <algorithm>
using namespace std;
const char iname[] = "ssm.in";
const char oname[] = "ssm.out";
const int MAXN = 7000005;
#define FOR(i, a, b) for (int i = (a); i <= (b); ++ i)
#define Max(a, b) ((a) > (b) ? (a) : (b))
int main(void) {
ifstream in(iname);
int n, S;
int bestSum = -int(2e9), sum = 0, beg, end, idx;
in >> n;
FOR (i, 1, n) {
in >> S;
if (sum < 0)
sum = S, idx = i;
else
sum += S;
if (bestSum < sum)
bestSum = sum, beg = idx, end = i;
}
ofstream out(oname);
out << bestSum << " " << beg << " " << end;
in.close(), out.close();
return 0;
}