Pagini recente » Cod sursa (job #366363) | Cod sursa (job #303257) | Cod sursa (job #1101685) | Cod sursa (job #40096) | Cod sursa (job #2239415)
#include <iostream>
#include <fstream>
#include <climits>
using namespace std;
ifstream f ("ssm.in");
ofstream g ("ssm.out");
int n,v[6000006];
int sp[6000006];
int minim = INT_MAX;
int maxim = INT_MIN;
int maxpoz=1,minpoz =1;
int main()
{
f>>n;
for(int i=1;i<=n;i++)
f>>v[i];
sp[-1] = INT_MIN;
for(int i=1;i<=n;i++)
{
sp[i] = sp[i-1] + v[i];
if(sp[i-1]<minim){
minim = sp[i-1];
}
if(sp[i] - minim > maxim){
maxim = sp[i] - minim ;
maxpoz = i;
}
}
int i = maxpoz;
int sum = v[maxpoz];
while (sum != maxim)
{
i--;
sum+=v[i];
}
int mini=i;
if(v[mini-1]==0)
mini=i-1;
g<<maxim<<' '<<mini<<' '<<maxpoz;
return 0;
}