Cod sursa(job #2956431)
Utilizator | Data | 19 decembrie 2022 15:40:00 | |
---|---|---|---|
Problema | Subsecventa de suma maxima | Scor | 100 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva educationala | Marime | 0.63 kb |
#include <fstream>
using namespace std;
const int INF = 2e9;
int main()
{
ifstream fin("ssm.in");
ofstream fout("ssm.out");
int n, sc = -1, smax = -INF, st, stmax, drmax;
fin >> n;
for(int i = 1; i <= n; i++)
{
int x_i;
fin >> x_i;
if(x_i > sc + x_i)
{
sc = x_i;
st = i;
}
else
sc += x_i;
if(sc > smax)
{
smax = sc;
stmax = st;
drmax = i;
}
}
fout << smax << ' ' << stmax << ' ' << drmax;
fin.close();
fout.close();
return 0;
}