Pagini recente » Cod sursa (job #415935) | Monitorul de evaluare | Cod sursa (job #2869725) | Cod sursa (job #1462495) | Cod sursa (job #1771657)
#include <iostream>
#include <fstream>
using namespace std;
ifstream in("secv2.in");
ofstream out("secv2.out");
int c[50005], t[50005], v[50005];
int mx = 0, d = 0, sum = 0;
int main()
{
int n, k;
in >> n >> k;
for(int i = 1; i <= n; i++){
in >> v[i];
t[i] = t[i-1] + v[i];
}
int mn = 1000000000;
for(int i = k; i <= n; i++){
mn = min(mn, t[i-k]);
c[i] = max(c[i-1], t[i] - mn);
}
for(int i = k; i <= n; i++)
mx = max(mx, c[i]);
for(int i = k; i <= n; i++){
if(c[i] == mx){
d = i;
break;
}
}
int s = d;
while(sum != mx || d - s + 1 < k){
if(s >= 0)
sum += v[s];
s --;
}
out << s + 1 << " " << d << " " << mx;
return 0;
}