Cod sursa(job #3272729)
Utilizator | Data | 30 ianuarie 2025 19:47:44 | |
---|---|---|---|
Problema | Subsecventa de suma maxima | Scor | 100 |
Compilator | cpp-64 | Status | done |
Runda | Arhiva educationala | Marime | 0.61 kb |
#include <fstream>
#include <climits>
using namespace std;
ifstream in("ssm.in");
ofstream out("ssm.out");
int main() {
int n;
in >> n;
int sc_i = 0, st = 1, st_max, dr_max, s_max = INT_MIN;
for (int i = 1 ; i <= n ; ++i) {
int x_i;
in >> x_i;
if (x_i > sc_i + x_i) {
sc_i = x_i;
st = i;
}
else sc_i += x_i;
if (sc_i > s_max) {
s_max = sc_i;
dr_max = i;
st_max = st;
}
}
out << s_max << " " << st_max << " " << dr_max << "\n";
in.close();
out.close();
return 0;
}