Pagini recente » Cod sursa (job #3243690) | Cod sursa (job #3202932) | Cod sursa (job #2863) | Cod sursa (job #2907055) | Cod sursa (job #3275072)
#include <bits/stdc++.h>
using namespace std;
ifstream in("ssm.in");
ofstream out("ssm.out");
int main(void) {
int n, x, idx_start = 1, temp_start = 1, idx_end = 1;
long long sum = 0, sum_max = LLONG_MIN;
in >> n;
for (int i = 1; i <= n; i++) {
in >> x;
if (sum + x > x) {
sum += x;
} else {
sum = x;
temp_start = i;
}
if (sum > sum_max) {
sum_max = sum;
idx_start = temp_start;
idx_end = i;
} else if (sum == sum_max) {
if (i - temp_start < idx_end - idx_start) {
idx_end = i;
idx_start = temp_start;
}
}
}
out << sum_max << " " << idx_start << " " << idx_end;
return 0;
}