Pagini recente » Istoria paginii utilizator/xeress | Cod sursa (job #1590075) | Cod sursa (job #2184249) | Cod sursa (job #2472439) | Cod sursa (job #2674955)
#include <fstream>
using namespace std;
ifstream fin("ssm.in");
ofstream fout("ssm.out");
int sume_partiale[6000005], suma_minima, suma_max = -1000000, n, stocare[6000005], secv[6000005], stanga, dreapta;
int main()
{
fin >> n;
for (int i = 1; i <= n; i++)
fin >> stocare[i];
for (int i = 1; i <= n; i++)
sume_partiale[i] = stocare[i] + sume_partiale[i - 1];
suma_minima = sume_partiale[0];
for (int i = 1; i <= n; i++)
{
secv[i] = sume_partiale[i] - suma_minima;
if (suma_minima > sume_partiale[i])
suma_minima = sume_partiale[i];
if (suma_max < secv[i])
suma_max = secv[i], dreapta = i;
}
for (int i = 1; i <= n; i++)
if (suma_minima == sume_partiale[i])
stanga = i + 1;
fout << suma_max << " " << stanga << " " << dreapta;
return 0;
}